{"version":3,"file":"892.7388a40a.js","mappings":"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","sources":["webpack://@finviz/website/../node_modules/core-js/internals/array-set-length.js","webpack://@finviz/website/../node_modules/core-js/internals/does-not-exceed-safe-integer.js","webpack://@finviz/website/../node_modules/core-js/modules/es.array.push.js","webpack://@finviz/website/../node_modules/d3-array/src/ascending.js","webpack://@finviz/website/../node_modules/d3-array/src/bisect.js","webpack://@finviz/website/../node_modules/d3-array/src/descending.js","webpack://@finviz/website/../node_modules/d3-array/src/bisector.js","webpack://@finviz/website/../node_modules/d3-array/src/max.js","webpack://@finviz/website/../node_modules/d3-array/src/min.js","webpack://@finviz/website/../node_modules/d3-array/src/number.js","webpack://@finviz/website/../node_modules/d3-array/src/ticks.js","webpack://@finviz/website/../node_modules/d3-color/src/define.js","webpack://@finviz/website/../node_modules/d3-color/src/color.js","webpack://@finviz/website/../node_modules/d3-format/src/formatPrefixAuto.js","webpack://@finviz/website/../node_modules/d3-format/src/formatRounded.js","webpack://@finviz/website/../node_modules/d3-format/src/formatTypes.js","webpack://@finviz/website/../node_modules/d3-format/src/identity.js","webpack://@finviz/website/../node_modules/d3-format/src/locale.js","webpack://@finviz/website/../node_modules/d3-format/src/defaultLocale.js","webpack://@finviz/website/../node_modules/d3-format/src/formatGroup.js","webpack://@finviz/website/../node_modules/d3-format/src/formatNumerals.js","webpack://@finviz/website/../node_modules/d3-format/src/formatTrim.js","webpack://@finviz/website/../node_modules/d3-format/src/exponent.js","webpack://@finviz/website/../node_modules/d3-format/src/formatDecimal.js","webpack://@finviz/website/../node_modules/d3-format/src/formatSpecifier.js","webpack://@finviz/website/../node_modules/d3-interpolate/src/constant.js","webpack://@finviz/website/../node_modules/d3-interpolate/src/number.js","webpack://@finviz/website/../node_modules/d3-interpolate/src/basis.js","webpack://@finviz/website/../node_modules/d3-interpolate/src/color.js","webpack://@finviz/website/../node_modules/d3-interpolate/src/rgb.js","webpack://@finviz/website/../node_modules/d3-interpolate/src/basisClosed.js","webpack://@finviz/website/../node_modules/d3-interpolate/src/round.js","webpack://@finviz/website/../node_modules/d3-interpolate/src/string.js","webpack://@finviz/website/../node_modules/d3-interpolate/src/array.js","webpack://@finviz/website/../node_modules/d3-interpolate/src/date.js","webpack://@finviz/website/../node_modules/d3-interpolate/src/object.js","webpack://@finviz/website/../node_modules/d3-interpolate/src/numberArray.js","webpack://@finviz/website/../node_modules/d3-interpolate/src/value.js","webpack://@finviz/website/../node_modules/d3-scale/src/band.js","webpack://@finviz/website/../node_modules/d3-array/src/range.js","webpack://@finviz/website/../node_modules/d3-scale/src/continuous.js","webpack://@finviz/website/../node_modules/d3-scale/src/constant.js","webpack://@finviz/website/../node_modules/d3-scale/src/identity.js","webpack://@finviz/website/../node_modules/d3-scale/src/nice.js","webpack://@finviz/website/../node_modules/d3-scale/src/log.js","webpack://@finviz/website/../node_modules/d3-scale/src/symlog.js","webpack://@finviz/website/../node_modules/d3-scale/src/pow.js","webpack://@finviz/website/../node_modules/d3-scale/src/radial.js","webpack://@finviz/website/../node_modules/d3-array/src/sort.js","webpack://@finviz/website/../node_modules/d3-array/src/quickselect.js","webpack://@finviz/website/../node_modules/d3-array/src/quantile.js","webpack://@finviz/website/../node_modules/d3-scale/src/quantile.js","webpack://@finviz/website/../node_modules/d3-scale/src/quantize.js","webpack://@finviz/website/../node_modules/d3-scale/src/threshold.js","webpack://@finviz/website/../node_modules/d3-time/src/duration.js","webpack://@finviz/website/../node_modules/d3-time/src/interval.js","webpack://@finviz/website/../node_modules/d3-time/src/millisecond.js","webpack://@finviz/website/../node_modules/d3-time/src/second.js","webpack://@finviz/website/../node_modules/d3-time/src/minute.js","webpack://@finviz/website/../node_modules/d3-time/src/hour.js","webpack://@finviz/website/../node_modules/d3-time/src/day.js","webpack://@finviz/website/../node_modules/d3-time/src/week.js","webpack://@finviz/website/../node_modules/d3-time/src/month.js","webpack://@finviz/website/../node_modules/d3-time/src/year.js","webpack://@finviz/website/../node_modules/d3-time/src/utcMinute.js","webpack://@finviz/website/../node_modules/d3-time/src/utcHour.js","webpack://@finviz/website/../node_modules/d3-time/src/utcDay.js","webpack://@finviz/website/../node_modules/d3-time/src/utcWeek.js","webpack://@finviz/website/../node_modules/d3-time/src/utcMonth.js","webpack://@finviz/website/../node_modules/d3-time/src/utcYear.js","webpack://@finviz/website/../node_modules/d3-time/src/ticks.js","webpack://@finviz/website/../node_modules/d3-time-format/src/locale.js","webpack://@finviz/website/../node_modules/d3-time-format/src/defaultLocale.js","webpack://@finviz/website/../node_modules/d3-scale/src/time.js","webpack://@finviz/website/../node_modules/d3-scale/src/utcTime.js","webpack://@finviz/website/../node_modules/d3-scale/src/sequential.js","webpack://@finviz/website/../node_modules/d3-scale/src/sequentialQuantile.js","webpack://@finviz/website/../node_modules/d3-scale/src/diverging.js","webpack://@finviz/website/../node_modules/d3-interpolate/src/piecewise.js","webpack://@finviz/website/../node_modules/d3-scale/src/init.js","webpack://@finviz/website/../node_modules/d3-scale/src/linear.js","webpack://@finviz/website/../node_modules/d3-scale/src/number.js","webpack://@finviz/website/../node_modules/internmap/src/index.js","webpack://@finviz/website/../node_modules/d3-scale/src/ordinal.js","webpack://@finviz/website/../node_modules/d3-scale/src/tickFormat.js","webpack://@finviz/website/../node_modules/d3-format/src/precisionPrefix.js","webpack://@finviz/website/../node_modules/d3-format/src/precisionRound.js","webpack://@finviz/website/../node_modules/d3-format/src/precisionFixed.js"],"sourcesContent":["'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar isArray = require('../internals/is-array');\n\nvar $TypeError = TypeError;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\n\n// Safari < 13 does not throw an error in this case\nvar SILENT_ON_NON_WRITABLE_LENGTH_SET = DESCRIPTORS && !function () {\n // makes no sense without proper strict mode support\n if (this !== undefined) return true;\n try {\n // eslint-disable-next-line es/no-object-defineproperty -- safe\n Object.defineProperty([], 'length', { writable: false }).length = 1;\n } catch (error) {\n return error instanceof TypeError;\n }\n}();\n\nmodule.exports = SILENT_ON_NON_WRITABLE_LENGTH_SET ? function (O, length) {\n if (isArray(O) && !getOwnPropertyDescriptor(O, 'length').writable) {\n throw new $TypeError('Cannot set read only .length');\n } return O.length = length;\n} : function (O, length) {\n return O.length = length;\n};\n","'use strict';\nvar $TypeError = TypeError;\nvar MAX_SAFE_INTEGER = 0x1FFFFFFFFFFFFF; // 2 ** 53 - 1 == 9007199254740991\n\nmodule.exports = function (it) {\n if (it > MAX_SAFE_INTEGER) throw $TypeError('Maximum allowed index exceeded');\n return it;\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar toObject = require('../internals/to-object');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\nvar setArrayLength = require('../internals/array-set-length');\nvar doesNotExceedSafeInteger = require('../internals/does-not-exceed-safe-integer');\nvar fails = require('../internals/fails');\n\nvar INCORRECT_TO_LENGTH = fails(function () {\n return [].push.call({ length: 0x100000000 }, 1) !== 4294967297;\n});\n\n// V8 <= 121 and Safari <= 15.4; FF < 23 throws InternalError\n// https://bugs.chromium.org/p/v8/issues/detail?id=12681\nvar properErrorOnNonWritableLength = function () {\n try {\n // eslint-disable-next-line es/no-object-defineproperty -- safe\n Object.defineProperty([], 'length', { writable: false }).push();\n } catch (error) {\n return error instanceof TypeError;\n }\n};\n\nvar FORCED = INCORRECT_TO_LENGTH || !properErrorOnNonWritableLength();\n\n// `Array.prototype.push` method\n// https://tc39.es/ecma262/#sec-array.prototype.push\n$({ target: 'Array', proto: true, arity: 1, forced: FORCED }, {\n // eslint-disable-next-line no-unused-vars -- required for `.length`\n push: function push(item) {\n var O = toObject(this);\n var len = lengthOfArrayLike(O);\n var argCount = arguments.length;\n doesNotExceedSafeInteger(len + argCount);\n for (var i = 0; i < argCount; i++) {\n O[len] = arguments[i];\n len++;\n }\n setArrayLength(O, len);\n return len;\n }\n});\n","export default function ascending(a, b) {\n return a == null || b == null ? NaN : a < b ? -1 : a > b ? 1 : a >= b ? 0 : NaN;\n}\n","import ascending from \"./ascending.js\";\nimport bisector from \"./bisector.js\";\nimport number from \"./number.js\";\n\nconst ascendingBisect = bisector(ascending);\nexport const bisectRight = ascendingBisect.right;\nexport const bisectLeft = ascendingBisect.left;\nexport const bisectCenter = bisector(number).center;\nexport default bisectRight;\n","export default function descending(a, b) {\n return a == null || b == null ? NaN\n : b < a ? -1\n : b > a ? 1\n : b >= a ? 0\n : NaN;\n}\n","import ascending from \"./ascending.js\";\nimport descending from \"./descending.js\";\n\nexport default function bisector(f) {\n let compare1, compare2, delta;\n\n // If an accessor is specified, promote it to a comparator. In this case we\n // can test whether the search value is (self-) comparable. We can’t do this\n // for a comparator (except for specific, known comparators) because we can’t\n // tell if the comparator is symmetric, and an asymmetric comparator can’t be\n // used to test whether a single value is comparable.\n if (f.length !== 2) {\n compare1 = ascending;\n compare2 = (d, x) => ascending(f(d), x);\n delta = (d, x) => f(d) - x;\n } else {\n compare1 = f === ascending || f === descending ? f : zero;\n compare2 = f;\n delta = f;\n }\n\n function left(a, x, lo = 0, hi = a.length) {\n if (lo < hi) {\n if (compare1(x, x) !== 0) return hi;\n do {\n const mid = (lo + hi) >>> 1;\n if (compare2(a[mid], x) < 0) lo = mid + 1;\n else hi = mid;\n } while (lo < hi);\n }\n return lo;\n }\n\n function right(a, x, lo = 0, hi = a.length) {\n if (lo < hi) {\n if (compare1(x, x) !== 0) return hi;\n do {\n const mid = (lo + hi) >>> 1;\n if (compare2(a[mid], x) <= 0) lo = mid + 1;\n else hi = mid;\n } while (lo < hi);\n }\n return lo;\n }\n\n function center(a, x, lo = 0, hi = a.length) {\n const i = left(a, x, lo, hi - 1);\n return i > lo && delta(a[i - 1], x) > -delta(a[i], x) ? i - 1 : i;\n }\n\n return {left, center, right};\n}\n\nfunction zero() {\n return 0;\n}\n","export default function max(values, valueof) {\n let max;\n if (valueof === undefined) {\n for (const value of values) {\n if (value != null\n && (max < value || (max === undefined && value >= value))) {\n max = value;\n }\n }\n } else {\n let index = -1;\n for (let value of values) {\n if ((value = valueof(value, ++index, values)) != null\n && (max < value || (max === undefined && value >= value))) {\n max = value;\n }\n }\n }\n return max;\n}\n","export default function min(values, valueof) {\n let min;\n if (valueof === undefined) {\n for (const value of values) {\n if (value != null\n && (min > value || (min === undefined && value >= value))) {\n min = value;\n }\n }\n } else {\n let index = -1;\n for (let value of values) {\n if ((value = valueof(value, ++index, values)) != null\n && (min > value || (min === undefined && value >= value))) {\n min = value;\n }\n }\n }\n return min;\n}\n","export default function number(x) {\n return x === null ? NaN : +x;\n}\n\nexport function* numbers(values, valueof) {\n if (valueof === undefined) {\n for (let value of values) {\n if (value != null && (value = +value) >= value) {\n yield value;\n }\n }\n } else {\n let index = -1;\n for (let value of values) {\n if ((value = valueof(value, ++index, values)) != null && (value = +value) >= value) {\n yield value;\n }\n }\n }\n}\n","var e10 = Math.sqrt(50),\n e5 = Math.sqrt(10),\n e2 = Math.sqrt(2);\n\nexport default function ticks(start, stop, count) {\n var reverse,\n i = -1,\n n,\n ticks,\n step;\n\n stop = +stop, start = +start, count = +count;\n if (start === stop && count > 0) return [start];\n if (reverse = stop < start) n = start, start = stop, stop = n;\n if ((step = tickIncrement(start, stop, count)) === 0 || !isFinite(step)) return [];\n\n if (step > 0) {\n let r0 = Math.round(start / step), r1 = Math.round(stop / step);\n if (r0 * step < start) ++r0;\n if (r1 * step > stop) --r1;\n ticks = new Array(n = r1 - r0 + 1);\n while (++i < n) ticks[i] = (r0 + i) * step;\n } else {\n step = -step;\n let r0 = Math.round(start * step), r1 = Math.round(stop * step);\n if (r0 / step < start) ++r0;\n if (r1 / step > stop) --r1;\n ticks = new Array(n = r1 - r0 + 1);\n while (++i < n) ticks[i] = (r0 + i) / step;\n }\n\n if (reverse) ticks.reverse();\n\n return ticks;\n}\n\nexport function tickIncrement(start, stop, count) {\n var step = (stop - start) / Math.max(0, count),\n power = Math.floor(Math.log(step) / Math.LN10),\n error = step / Math.pow(10, power);\n return power >= 0\n ? (error >= e10 ? 10 : error >= e5 ? 5 : error >= e2 ? 2 : 1) * Math.pow(10, power)\n : -Math.pow(10, -power) / (error >= e10 ? 10 : error >= e5 ? 5 : error >= e2 ? 2 : 1);\n}\n\nexport function tickStep(start, stop, count) {\n var step0 = Math.abs(stop - start) / Math.max(0, count),\n step1 = Math.pow(10, Math.floor(Math.log(step0) / Math.LN10)),\n error = step0 / step1;\n if (error >= e10) step1 *= 10;\n else if (error >= e5) step1 *= 5;\n else if (error >= e2) step1 *= 2;\n return stop < start ? -step1 : step1;\n}\n","export default function(constructor, factory, prototype) {\n constructor.prototype = factory.prototype = prototype;\n prototype.constructor = constructor;\n}\n\nexport function extend(parent, definition) {\n var prototype = Object.create(parent.prototype);\n for (var key in definition) prototype[key] = definition[key];\n return prototype;\n}\n","import define, {extend} from \"./define.js\";\n\nexport function Color() {}\n\nexport var darker = 0.7;\nexport var brighter = 1 / darker;\n\nvar reI = \"\\\\s*([+-]?\\\\d+)\\\\s*\",\n reN = \"\\\\s*([+-]?(?:\\\\d*\\\\.)?\\\\d+(?:[eE][+-]?\\\\d+)?)\\\\s*\",\n reP = \"\\\\s*([+-]?(?:\\\\d*\\\\.)?\\\\d+(?:[eE][+-]?\\\\d+)?)%\\\\s*\",\n reHex = /^#([0-9a-f]{3,8})$/,\n reRgbInteger = new RegExp(`^rgb\\\\(${reI},${reI},${reI}\\\\)$`),\n reRgbPercent = new RegExp(`^rgb\\\\(${reP},${reP},${reP}\\\\)$`),\n reRgbaInteger = new RegExp(`^rgba\\\\(${reI},${reI},${reI},${reN}\\\\)$`),\n reRgbaPercent = new RegExp(`^rgba\\\\(${reP},${reP},${reP},${reN}\\\\)$`),\n reHslPercent = new RegExp(`^hsl\\\\(${reN},${reP},${reP}\\\\)$`),\n reHslaPercent = new RegExp(`^hsla\\\\(${reN},${reP},${reP},${reN}\\\\)$`);\n\nvar named = {\n aliceblue: 0xf0f8ff,\n antiquewhite: 0xfaebd7,\n aqua: 0x00ffff,\n aquamarine: 0x7fffd4,\n azure: 0xf0ffff,\n beige: 0xf5f5dc,\n bisque: 0xffe4c4,\n black: 0x000000,\n blanchedalmond: 0xffebcd,\n blue: 0x0000ff,\n blueviolet: 0x8a2be2,\n brown: 0xa52a2a,\n burlywood: 0xdeb887,\n cadetblue: 0x5f9ea0,\n chartreuse: 0x7fff00,\n chocolate: 0xd2691e,\n coral: 0xff7f50,\n cornflowerblue: 0x6495ed,\n cornsilk: 0xfff8dc,\n crimson: 0xdc143c,\n cyan: 0x00ffff,\n darkblue: 0x00008b,\n darkcyan: 0x008b8b,\n darkgoldenrod: 0xb8860b,\n darkgray: 0xa9a9a9,\n darkgreen: 0x006400,\n darkgrey: 0xa9a9a9,\n darkkhaki: 0xbdb76b,\n darkmagenta: 0x8b008b,\n darkolivegreen: 0x556b2f,\n darkorange: 0xff8c00,\n darkorchid: 0x9932cc,\n darkred: 0x8b0000,\n darksalmon: 0xe9967a,\n darkseagreen: 0x8fbc8f,\n darkslateblue: 0x483d8b,\n darkslategray: 0x2f4f4f,\n darkslategrey: 0x2f4f4f,\n darkturquoise: 0x00ced1,\n darkviolet: 0x9400d3,\n deeppink: 0xff1493,\n deepskyblue: 0x00bfff,\n dimgray: 0x696969,\n dimgrey: 0x696969,\n dodgerblue: 0x1e90ff,\n firebrick: 0xb22222,\n floralwhite: 0xfffaf0,\n forestgreen: 0x228b22,\n fuchsia: 0xff00ff,\n gainsboro: 0xdcdcdc,\n ghostwhite: 0xf8f8ff,\n gold: 0xffd700,\n goldenrod: 0xdaa520,\n gray: 0x808080,\n green: 0x008000,\n greenyellow: 0xadff2f,\n grey: 0x808080,\n honeydew: 0xf0fff0,\n hotpink: 0xff69b4,\n indianred: 0xcd5c5c,\n indigo: 0x4b0082,\n ivory: 0xfffff0,\n khaki: 0xf0e68c,\n lavender: 0xe6e6fa,\n lavenderblush: 0xfff0f5,\n lawngreen: 0x7cfc00,\n lemonchiffon: 0xfffacd,\n lightblue: 0xadd8e6,\n lightcoral: 0xf08080,\n lightcyan: 0xe0ffff,\n lightgoldenrodyellow: 0xfafad2,\n lightgray: 0xd3d3d3,\n lightgreen: 0x90ee90,\n lightgrey: 0xd3d3d3,\n lightpink: 0xffb6c1,\n lightsalmon: 0xffa07a,\n lightseagreen: 0x20b2aa,\n lightskyblue: 0x87cefa,\n lightslategray: 0x778899,\n lightslategrey: 0x778899,\n lightsteelblue: 0xb0c4de,\n lightyellow: 0xffffe0,\n lime: 0x00ff00,\n limegreen: 0x32cd32,\n linen: 0xfaf0e6,\n magenta: 0xff00ff,\n maroon: 0x800000,\n mediumaquamarine: 0x66cdaa,\n mediumblue: 0x0000cd,\n mediumorchid: 0xba55d3,\n mediumpurple: 0x9370db,\n mediumseagreen: 0x3cb371,\n mediumslateblue: 0x7b68ee,\n mediumspringgreen: 0x00fa9a,\n mediumturquoise: 0x48d1cc,\n mediumvioletred: 0xc71585,\n midnightblue: 0x191970,\n mintcream: 0xf5fffa,\n mistyrose: 0xffe4e1,\n moccasin: 0xffe4b5,\n navajowhite: 0xffdead,\n navy: 0x000080,\n oldlace: 0xfdf5e6,\n olive: 0x808000,\n olivedrab: 0x6b8e23,\n orange: 0xffa500,\n orangered: 0xff4500,\n orchid: 0xda70d6,\n palegoldenrod: 0xeee8aa,\n palegreen: 0x98fb98,\n paleturquoise: 0xafeeee,\n palevioletred: 0xdb7093,\n papayawhip: 0xffefd5,\n peachpuff: 0xffdab9,\n peru: 0xcd853f,\n pink: 0xffc0cb,\n plum: 0xdda0dd,\n powderblue: 0xb0e0e6,\n purple: 0x800080,\n rebeccapurple: 0x663399,\n red: 0xff0000,\n rosybrown: 0xbc8f8f,\n royalblue: 0x4169e1,\n saddlebrown: 0x8b4513,\n salmon: 0xfa8072,\n sandybrown: 0xf4a460,\n seagreen: 0x2e8b57,\n seashell: 0xfff5ee,\n sienna: 0xa0522d,\n silver: 0xc0c0c0,\n skyblue: 0x87ceeb,\n slateblue: 0x6a5acd,\n slategray: 0x708090,\n slategrey: 0x708090,\n snow: 0xfffafa,\n springgreen: 0x00ff7f,\n steelblue: 0x4682b4,\n tan: 0xd2b48c,\n teal: 0x008080,\n thistle: 0xd8bfd8,\n tomato: 0xff6347,\n turquoise: 0x40e0d0,\n violet: 0xee82ee,\n wheat: 0xf5deb3,\n white: 0xffffff,\n whitesmoke: 0xf5f5f5,\n yellow: 0xffff00,\n yellowgreen: 0x9acd32\n};\n\ndefine(Color, color, {\n copy(channels) {\n return Object.assign(new this.constructor, this, channels);\n },\n displayable() {\n return this.rgb().displayable();\n },\n hex: color_formatHex, // Deprecated! Use color.formatHex.\n formatHex: color_formatHex,\n formatHex8: color_formatHex8,\n formatHsl: color_formatHsl,\n formatRgb: color_formatRgb,\n toString: color_formatRgb\n});\n\nfunction color_formatHex() {\n return this.rgb().formatHex();\n}\n\nfunction color_formatHex8() {\n return this.rgb().formatHex8();\n}\n\nfunction color_formatHsl() {\n return hslConvert(this).formatHsl();\n}\n\nfunction color_formatRgb() {\n return this.rgb().formatRgb();\n}\n\nexport default function color(format) {\n var m, l;\n format = (format + \"\").trim().toLowerCase();\n return (m = reHex.exec(format)) ? (l = m[1].length, m = parseInt(m[1], 16), l === 6 ? rgbn(m) // #ff0000\n : l === 3 ? new Rgb((m >> 8 & 0xf) | (m >> 4 & 0xf0), (m >> 4 & 0xf) | (m & 0xf0), ((m & 0xf) << 4) | (m & 0xf), 1) // #f00\n : l === 8 ? rgba(m >> 24 & 0xff, m >> 16 & 0xff, m >> 8 & 0xff, (m & 0xff) / 0xff) // #ff000000\n : l === 4 ? rgba((m >> 12 & 0xf) | (m >> 8 & 0xf0), (m >> 8 & 0xf) | (m >> 4 & 0xf0), (m >> 4 & 0xf) | (m & 0xf0), (((m & 0xf) << 4) | (m & 0xf)) / 0xff) // #f000\n : null) // invalid hex\n : (m = reRgbInteger.exec(format)) ? new Rgb(m[1], m[2], m[3], 1) // rgb(255, 0, 0)\n : (m = reRgbPercent.exec(format)) ? new Rgb(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, 1) // rgb(100%, 0%, 0%)\n : (m = reRgbaInteger.exec(format)) ? rgba(m[1], m[2], m[3], m[4]) // rgba(255, 0, 0, 1)\n : (m = reRgbaPercent.exec(format)) ? rgba(m[1] * 255 / 100, m[2] * 255 / 100, m[3] * 255 / 100, m[4]) // rgb(100%, 0%, 0%, 1)\n : (m = reHslPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, 1) // hsl(120, 50%, 50%)\n : (m = reHslaPercent.exec(format)) ? hsla(m[1], m[2] / 100, m[3] / 100, m[4]) // hsla(120, 50%, 50%, 1)\n : named.hasOwnProperty(format) ? rgbn(named[format]) // eslint-disable-line no-prototype-builtins\n : format === \"transparent\" ? new Rgb(NaN, NaN, NaN, 0)\n : null;\n}\n\nfunction rgbn(n) {\n return new Rgb(n >> 16 & 0xff, n >> 8 & 0xff, n & 0xff, 1);\n}\n\nfunction rgba(r, g, b, a) {\n if (a <= 0) r = g = b = NaN;\n return new Rgb(r, g, b, a);\n}\n\nexport function rgbConvert(o) {\n if (!(o instanceof Color)) o = color(o);\n if (!o) return new Rgb;\n o = o.rgb();\n return new Rgb(o.r, o.g, o.b, o.opacity);\n}\n\nexport function rgb(r, g, b, opacity) {\n return arguments.length === 1 ? rgbConvert(r) : new Rgb(r, g, b, opacity == null ? 1 : opacity);\n}\n\nexport function Rgb(r, g, b, opacity) {\n this.r = +r;\n this.g = +g;\n this.b = +b;\n this.opacity = +opacity;\n}\n\ndefine(Rgb, rgb, extend(Color, {\n brighter(k) {\n k = k == null ? brighter : Math.pow(brighter, k);\n return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n },\n darker(k) {\n k = k == null ? darker : Math.pow(darker, k);\n return new Rgb(this.r * k, this.g * k, this.b * k, this.opacity);\n },\n rgb() {\n return this;\n },\n clamp() {\n return new Rgb(clampi(this.r), clampi(this.g), clampi(this.b), clampa(this.opacity));\n },\n displayable() {\n return (-0.5 <= this.r && this.r < 255.5)\n && (-0.5 <= this.g && this.g < 255.5)\n && (-0.5 <= this.b && this.b < 255.5)\n && (0 <= this.opacity && this.opacity <= 1);\n },\n hex: rgb_formatHex, // Deprecated! Use color.formatHex.\n formatHex: rgb_formatHex,\n formatHex8: rgb_formatHex8,\n formatRgb: rgb_formatRgb,\n toString: rgb_formatRgb\n}));\n\nfunction rgb_formatHex() {\n return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}`;\n}\n\nfunction rgb_formatHex8() {\n return `#${hex(this.r)}${hex(this.g)}${hex(this.b)}${hex((isNaN(this.opacity) ? 1 : this.opacity) * 255)}`;\n}\n\nfunction rgb_formatRgb() {\n const a = clampa(this.opacity);\n return `${a === 1 ? \"rgb(\" : \"rgba(\"}${clampi(this.r)}, ${clampi(this.g)}, ${clampi(this.b)}${a === 1 ? \")\" : `, ${a})`}`;\n}\n\nfunction clampa(opacity) {\n return isNaN(opacity) ? 1 : Math.max(0, Math.min(1, opacity));\n}\n\nfunction clampi(value) {\n return Math.max(0, Math.min(255, Math.round(value) || 0));\n}\n\nfunction hex(value) {\n value = clampi(value);\n return (value < 16 ? \"0\" : \"\") + value.toString(16);\n}\n\nfunction hsla(h, s, l, a) {\n if (a <= 0) h = s = l = NaN;\n else if (l <= 0 || l >= 1) h = s = NaN;\n else if (s <= 0) h = NaN;\n return new Hsl(h, s, l, a);\n}\n\nexport function hslConvert(o) {\n if (o instanceof Hsl) return new Hsl(o.h, o.s, o.l, o.opacity);\n if (!(o instanceof Color)) o = color(o);\n if (!o) return new Hsl;\n if (o instanceof Hsl) return o;\n o = o.rgb();\n var r = o.r / 255,\n g = o.g / 255,\n b = o.b / 255,\n min = Math.min(r, g, b),\n max = Math.max(r, g, b),\n h = NaN,\n s = max - min,\n l = (max + min) / 2;\n if (s) {\n if (r === max) h = (g - b) / s + (g < b) * 6;\n else if (g === max) h = (b - r) / s + 2;\n else h = (r - g) / s + 4;\n s /= l < 0.5 ? max + min : 2 - max - min;\n h *= 60;\n } else {\n s = l > 0 && l < 1 ? 0 : h;\n }\n return new Hsl(h, s, l, o.opacity);\n}\n\nexport function hsl(h, s, l, opacity) {\n return arguments.length === 1 ? hslConvert(h) : new Hsl(h, s, l, opacity == null ? 1 : opacity);\n}\n\nfunction Hsl(h, s, l, opacity) {\n this.h = +h;\n this.s = +s;\n this.l = +l;\n this.opacity = +opacity;\n}\n\ndefine(Hsl, hsl, extend(Color, {\n brighter(k) {\n k = k == null ? brighter : Math.pow(brighter, k);\n return new Hsl(this.h, this.s, this.l * k, this.opacity);\n },\n darker(k) {\n k = k == null ? darker : Math.pow(darker, k);\n return new Hsl(this.h, this.s, this.l * k, this.opacity);\n },\n rgb() {\n var h = this.h % 360 + (this.h < 0) * 360,\n s = isNaN(h) || isNaN(this.s) ? 0 : this.s,\n l = this.l,\n m2 = l + (l < 0.5 ? l : 1 - l) * s,\n m1 = 2 * l - m2;\n return new Rgb(\n hsl2rgb(h >= 240 ? h - 240 : h + 120, m1, m2),\n hsl2rgb(h, m1, m2),\n hsl2rgb(h < 120 ? h + 240 : h - 120, m1, m2),\n this.opacity\n );\n },\n clamp() {\n return new Hsl(clamph(this.h), clampt(this.s), clampt(this.l), clampa(this.opacity));\n },\n displayable() {\n return (0 <= this.s && this.s <= 1 || isNaN(this.s))\n && (0 <= this.l && this.l <= 1)\n && (0 <= this.opacity && this.opacity <= 1);\n },\n formatHsl() {\n const a = clampa(this.opacity);\n return `${a === 1 ? \"hsl(\" : \"hsla(\"}${clamph(this.h)}, ${clampt(this.s) * 100}%, ${clampt(this.l) * 100}%${a === 1 ? \")\" : `, ${a})`}`;\n }\n}));\n\nfunction clamph(value) {\n value = (value || 0) % 360;\n return value < 0 ? value + 360 : value;\n}\n\nfunction clampt(value) {\n return Math.max(0, Math.min(1, value || 0));\n}\n\n/* From FvD 13.37, CSS Color Module Level 3 */\nfunction hsl2rgb(h, m1, m2) {\n return (h < 60 ? m1 + (m2 - m1) * h / 60\n : h < 180 ? m2\n : h < 240 ? m1 + (m2 - m1) * (240 - h) / 60\n : m1) * 255;\n}\n","import {formatDecimalParts} from \"./formatDecimal.js\";\n\nexport var prefixExponent;\n\nexport default function(x, p) {\n var d = formatDecimalParts(x, p);\n if (!d) return x + \"\";\n var coefficient = d[0],\n exponent = d[1],\n i = exponent - (prefixExponent = Math.max(-8, Math.min(8, Math.floor(exponent / 3))) * 3) + 1,\n n = coefficient.length;\n return i === n ? coefficient\n : i > n ? coefficient + new Array(i - n + 1).join(\"0\")\n : i > 0 ? coefficient.slice(0, i) + \".\" + coefficient.slice(i)\n : \"0.\" + new Array(1 - i).join(\"0\") + formatDecimalParts(x, Math.max(0, p + i - 1))[0]; // less than 1y!\n}\n","import {formatDecimalParts} from \"./formatDecimal.js\";\n\nexport default function(x, p) {\n var d = formatDecimalParts(x, p);\n if (!d) return x + \"\";\n var coefficient = d[0],\n exponent = d[1];\n return exponent < 0 ? \"0.\" + new Array(-exponent).join(\"0\") + coefficient\n : coefficient.length > exponent + 1 ? coefficient.slice(0, exponent + 1) + \".\" + coefficient.slice(exponent + 1)\n : coefficient + new Array(exponent - coefficient.length + 2).join(\"0\");\n}\n","import formatDecimal from \"./formatDecimal.js\";\nimport formatPrefixAuto from \"./formatPrefixAuto.js\";\nimport formatRounded from \"./formatRounded.js\";\n\nexport default {\n \"%\": (x, p) => (x * 100).toFixed(p),\n \"b\": (x) => Math.round(x).toString(2),\n \"c\": (x) => x + \"\",\n \"d\": formatDecimal,\n \"e\": (x, p) => x.toExponential(p),\n \"f\": (x, p) => x.toFixed(p),\n \"g\": (x, p) => x.toPrecision(p),\n \"o\": (x) => Math.round(x).toString(8),\n \"p\": (x, p) => formatRounded(x * 100, p),\n \"r\": formatRounded,\n \"s\": formatPrefixAuto,\n \"X\": (x) => Math.round(x).toString(16).toUpperCase(),\n \"x\": (x) => Math.round(x).toString(16)\n};\n","export default function(x) {\n return x;\n}\n","import exponent from \"./exponent.js\";\nimport formatGroup from \"./formatGroup.js\";\nimport formatNumerals from \"./formatNumerals.js\";\nimport formatSpecifier from \"./formatSpecifier.js\";\nimport formatTrim from \"./formatTrim.js\";\nimport formatTypes from \"./formatTypes.js\";\nimport {prefixExponent} from \"./formatPrefixAuto.js\";\nimport identity from \"./identity.js\";\n\nvar map = Array.prototype.map,\n prefixes = [\"y\",\"z\",\"a\",\"f\",\"p\",\"n\",\"µ\",\"m\",\"\",\"k\",\"M\",\"G\",\"T\",\"P\",\"E\",\"Z\",\"Y\"];\n\nexport default function(locale) {\n var group = locale.grouping === undefined || locale.thousands === undefined ? identity : formatGroup(map.call(locale.grouping, Number), locale.thousands + \"\"),\n currencyPrefix = locale.currency === undefined ? \"\" : locale.currency[0] + \"\",\n currencySuffix = locale.currency === undefined ? \"\" : locale.currency[1] + \"\",\n decimal = locale.decimal === undefined ? \".\" : locale.decimal + \"\",\n numerals = locale.numerals === undefined ? identity : formatNumerals(map.call(locale.numerals, String)),\n percent = locale.percent === undefined ? \"%\" : locale.percent + \"\",\n minus = locale.minus === undefined ? \"−\" : locale.minus + \"\",\n nan = locale.nan === undefined ? \"NaN\" : locale.nan + \"\";\n\n function newFormat(specifier) {\n specifier = formatSpecifier(specifier);\n\n var fill = specifier.fill,\n align = specifier.align,\n sign = specifier.sign,\n symbol = specifier.symbol,\n zero = specifier.zero,\n width = specifier.width,\n comma = specifier.comma,\n precision = specifier.precision,\n trim = specifier.trim,\n type = specifier.type;\n\n // The \"n\" type is an alias for \",g\".\n if (type === \"n\") comma = true, type = \"g\";\n\n // The \"\" type, and any invalid type, is an alias for \".12~g\".\n else if (!formatTypes[type]) precision === undefined && (precision = 12), trim = true, type = \"g\";\n\n // If zero fill is specified, padding goes after sign and before digits.\n if (zero || (fill === \"0\" && align === \"=\")) zero = true, fill = \"0\", align = \"=\";\n\n // Compute the prefix and suffix.\n // For SI-prefix, the suffix is lazily computed.\n var prefix = symbol === \"$\" ? currencyPrefix : symbol === \"#\" && /[boxX]/.test(type) ? \"0\" + type.toLowerCase() : \"\",\n suffix = symbol === \"$\" ? currencySuffix : /[%p]/.test(type) ? percent : \"\";\n\n // What format function should we use?\n // Is this an integer type?\n // Can this type generate exponential notation?\n var formatType = formatTypes[type],\n maybeSuffix = /[defgprs%]/.test(type);\n\n // Set the default precision if not specified,\n // or clamp the specified precision to the supported range.\n // For significant precision, it must be in [1, 21].\n // For fixed precision, it must be in [0, 20].\n precision = precision === undefined ? 6\n : /[gprs]/.test(type) ? Math.max(1, Math.min(21, precision))\n : Math.max(0, Math.min(20, precision));\n\n function format(value) {\n var valuePrefix = prefix,\n valueSuffix = suffix,\n i, n, c;\n\n if (type === \"c\") {\n valueSuffix = formatType(value) + valueSuffix;\n value = \"\";\n } else {\n value = +value;\n\n // Determine the sign. -0 is not less than 0, but 1 / -0 is!\n var valueNegative = value < 0 || 1 / value < 0;\n\n // Perform the initial formatting.\n value = isNaN(value) ? nan : formatType(Math.abs(value), precision);\n\n // Trim insignificant zeros.\n if (trim) value = formatTrim(value);\n\n // If a negative value rounds to zero after formatting, and no explicit positive sign is requested, hide the sign.\n if (valueNegative && +value === 0 && sign !== \"+\") valueNegative = false;\n\n // Compute the prefix and suffix.\n valuePrefix = (valueNegative ? (sign === \"(\" ? sign : minus) : sign === \"-\" || sign === \"(\" ? \"\" : sign) + valuePrefix;\n valueSuffix = (type === \"s\" ? prefixes[8 + prefixExponent / 3] : \"\") + valueSuffix + (valueNegative && sign === \"(\" ? \")\" : \"\");\n\n // Break the formatted value into the integer “value” part that can be\n // grouped, and fractional or exponential “suffix” part that is not.\n if (maybeSuffix) {\n i = -1, n = value.length;\n while (++i < n) {\n if (c = value.charCodeAt(i), 48 > c || c > 57) {\n valueSuffix = (c === 46 ? decimal + value.slice(i + 1) : value.slice(i)) + valueSuffix;\n value = value.slice(0, i);\n break;\n }\n }\n }\n }\n\n // If the fill character is not \"0\", grouping is applied before padding.\n if (comma && !zero) value = group(value, Infinity);\n\n // Compute the padding.\n var length = valuePrefix.length + value.length + valueSuffix.length,\n padding = length < width ? new Array(width - length + 1).join(fill) : \"\";\n\n // If the fill character is \"0\", grouping is applied after padding.\n if (comma && zero) value = group(padding + value, padding.length ? width - valueSuffix.length : Infinity), padding = \"\";\n\n // Reconstruct the final output based on the desired alignment.\n switch (align) {\n case \"<\": value = valuePrefix + value + valueSuffix + padding; break;\n case \"=\": value = valuePrefix + padding + value + valueSuffix; break;\n case \"^\": value = padding.slice(0, length = padding.length >> 1) + valuePrefix + value + valueSuffix + padding.slice(length); break;\n default: value = padding + valuePrefix + value + valueSuffix; break;\n }\n\n return numerals(value);\n }\n\n format.toString = function() {\n return specifier + \"\";\n };\n\n return format;\n }\n\n function formatPrefix(specifier, value) {\n var f = newFormat((specifier = formatSpecifier(specifier), specifier.type = \"f\", specifier)),\n e = Math.max(-8, Math.min(8, Math.floor(exponent(value) / 3))) * 3,\n k = Math.pow(10, -e),\n prefix = prefixes[8 + e / 3];\n return function(value) {\n return f(k * value) + prefix;\n };\n }\n\n return {\n format: newFormat,\n formatPrefix: formatPrefix\n };\n}\n","import formatLocale from \"./locale.js\";\n\nvar locale;\nexport var format;\nexport var formatPrefix;\n\ndefaultLocale({\n thousands: \",\",\n grouping: [3],\n currency: [\"$\", \"\"]\n});\n\nexport default function defaultLocale(definition) {\n locale = formatLocale(definition);\n format = locale.format;\n formatPrefix = locale.formatPrefix;\n return locale;\n}\n","export default function(grouping, thousands) {\n return function(value, width) {\n var i = value.length,\n t = [],\n j = 0,\n g = grouping[0],\n length = 0;\n\n while (i > 0 && g > 0) {\n if (length + g + 1 > width) g = Math.max(1, width - length);\n t.push(value.substring(i -= g, i + g));\n if ((length += g + 1) > width) break;\n g = grouping[j = (j + 1) % grouping.length];\n }\n\n return t.reverse().join(thousands);\n };\n}\n","export default function(numerals) {\n return function(value) {\n return value.replace(/[0-9]/g, function(i) {\n return numerals[+i];\n });\n };\n}\n","// Trims insignificant zeros, e.g., replaces 1.2000k with 1.2k.\nexport default function(s) {\n out: for (var n = s.length, i = 1, i0 = -1, i1; i < n; ++i) {\n switch (s[i]) {\n case \".\": i0 = i1 = i; break;\n case \"0\": if (i0 === 0) i0 = i; i1 = i; break;\n default: if (!+s[i]) break out; if (i0 > 0) i0 = 0; break;\n }\n }\n return i0 > 0 ? s.slice(0, i0) + s.slice(i1 + 1) : s;\n}\n","import {formatDecimalParts} from \"./formatDecimal.js\";\n\nexport default function(x) {\n return x = formatDecimalParts(Math.abs(x)), x ? x[1] : NaN;\n}\n","export default function(x) {\n return Math.abs(x = Math.round(x)) >= 1e21\n ? x.toLocaleString(\"en\").replace(/,/g, \"\")\n : x.toString(10);\n}\n\n// Computes the decimal coefficient and exponent of the specified number x with\n// significant digits p, where x is positive and p is in [1, 21] or undefined.\n// For example, formatDecimalParts(1.23) returns [\"123\", 0].\nexport function formatDecimalParts(x, p) {\n if ((i = (x = p ? x.toExponential(p - 1) : x.toExponential()).indexOf(\"e\")) < 0) return null; // NaN, ±Infinity\n var i, coefficient = x.slice(0, i);\n\n // The string returned by toExponential either has the form \\d\\.\\d+e[-+]\\d+\n // (e.g., 1.2e+3) or the form \\de[-+]\\d+ (e.g., 1e+3).\n return [\n coefficient.length > 1 ? coefficient[0] + coefficient.slice(2) : coefficient,\n +x.slice(i + 1)\n ];\n}\n","// [[fill]align][sign][symbol][0][width][,][.precision][~][type]\nvar re = /^(?:(.)?([<>=^]))?([+\\-( ])?([$#])?(0)?(\\d+)?(,)?(\\.\\d+)?(~)?([a-z%])?$/i;\n\nexport default function formatSpecifier(specifier) {\n if (!(match = re.exec(specifier))) throw new Error(\"invalid format: \" + specifier);\n var match;\n return new FormatSpecifier({\n fill: match[1],\n align: match[2],\n sign: match[3],\n symbol: match[4],\n zero: match[5],\n width: match[6],\n comma: match[7],\n precision: match[8] && match[8].slice(1),\n trim: match[9],\n type: match[10]\n });\n}\n\nformatSpecifier.prototype = FormatSpecifier.prototype; // instanceof\n\nexport function FormatSpecifier(specifier) {\n this.fill = specifier.fill === undefined ? \" \" : specifier.fill + \"\";\n this.align = specifier.align === undefined ? \">\" : specifier.align + \"\";\n this.sign = specifier.sign === undefined ? \"-\" : specifier.sign + \"\";\n this.symbol = specifier.symbol === undefined ? \"\" : specifier.symbol + \"\";\n this.zero = !!specifier.zero;\n this.width = specifier.width === undefined ? undefined : +specifier.width;\n this.comma = !!specifier.comma;\n this.precision = specifier.precision === undefined ? undefined : +specifier.precision;\n this.trim = !!specifier.trim;\n this.type = specifier.type === undefined ? \"\" : specifier.type + \"\";\n}\n\nFormatSpecifier.prototype.toString = function() {\n return this.fill\n + this.align\n + this.sign\n + this.symbol\n + (this.zero ? \"0\" : \"\")\n + (this.width === undefined ? \"\" : Math.max(1, this.width | 0))\n + (this.comma ? \",\" : \"\")\n + (this.precision === undefined ? \"\" : \".\" + Math.max(0, this.precision | 0))\n + (this.trim ? \"~\" : \"\")\n + this.type;\n};\n","export default x => () => x;\n","export default function(a, b) {\n return a = +a, b = +b, function(t) {\n return a * (1 - t) + b * t;\n };\n}\n","export function basis(t1, v0, v1, v2, v3) {\n var t2 = t1 * t1, t3 = t2 * t1;\n return ((1 - 3 * t1 + 3 * t2 - t3) * v0\n + (4 - 6 * t2 + 3 * t3) * v1\n + (1 + 3 * t1 + 3 * t2 - 3 * t3) * v2\n + t3 * v3) / 6;\n}\n\nexport default function(values) {\n var n = values.length - 1;\n return function(t) {\n var i = t <= 0 ? (t = 0) : t >= 1 ? (t = 1, n - 1) : Math.floor(t * n),\n v1 = values[i],\n v2 = values[i + 1],\n v0 = i > 0 ? values[i - 1] : 2 * v1 - v2,\n v3 = i < n - 1 ? values[i + 2] : 2 * v2 - v1;\n return basis((t - i / n) * n, v0, v1, v2, v3);\n };\n}\n","import constant from \"./constant.js\";\n\nfunction linear(a, d) {\n return function(t) {\n return a + t * d;\n };\n}\n\nfunction exponential(a, b, y) {\n return a = Math.pow(a, y), b = Math.pow(b, y) - a, y = 1 / y, function(t) {\n return Math.pow(a + t * b, y);\n };\n}\n\nexport function hue(a, b) {\n var d = b - a;\n return d ? linear(a, d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d) : constant(isNaN(a) ? b : a);\n}\n\nexport function gamma(y) {\n return (y = +y) === 1 ? nogamma : function(a, b) {\n return b - a ? exponential(a, b, y) : constant(isNaN(a) ? b : a);\n };\n}\n\nexport default function nogamma(a, b) {\n var d = b - a;\n return d ? linear(a, d) : constant(isNaN(a) ? b : a);\n}\n","import {rgb as colorRgb} from \"d3-color\";\nimport basis from \"./basis.js\";\nimport basisClosed from \"./basisClosed.js\";\nimport nogamma, {gamma} from \"./color.js\";\n\nexport default (function rgbGamma(y) {\n var color = gamma(y);\n\n function rgb(start, end) {\n var r = color((start = colorRgb(start)).r, (end = colorRgb(end)).r),\n g = color(start.g, end.g),\n b = color(start.b, end.b),\n opacity = nogamma(start.opacity, end.opacity);\n return function(t) {\n start.r = r(t);\n start.g = g(t);\n start.b = b(t);\n start.opacity = opacity(t);\n return start + \"\";\n };\n }\n\n rgb.gamma = rgbGamma;\n\n return rgb;\n})(1);\n\nfunction rgbSpline(spline) {\n return function(colors) {\n var n = colors.length,\n r = new Array(n),\n g = new Array(n),\n b = new Array(n),\n i, color;\n for (i = 0; i < n; ++i) {\n color = colorRgb(colors[i]);\n r[i] = color.r || 0;\n g[i] = color.g || 0;\n b[i] = color.b || 0;\n }\n r = spline(r);\n g = spline(g);\n b = spline(b);\n color.opacity = 1;\n return function(t) {\n color.r = r(t);\n color.g = g(t);\n color.b = b(t);\n return color + \"\";\n };\n };\n}\n\nexport var rgbBasis = rgbSpline(basis);\nexport var rgbBasisClosed = rgbSpline(basisClosed);\n","import {basis} from \"./basis.js\";\n\nexport default function(values) {\n var n = values.length;\n return function(t) {\n var i = Math.floor(((t %= 1) < 0 ? ++t : t) * n),\n v0 = values[(i + n - 1) % n],\n v1 = values[i % n],\n v2 = values[(i + 1) % n],\n v3 = values[(i + 2) % n];\n return basis((t - i / n) * n, v0, v1, v2, v3);\n };\n}\n","export default function(a, b) {\n return a = +a, b = +b, function(t) {\n return Math.round(a * (1 - t) + b * t);\n };\n}\n","import number from \"./number.js\";\n\nvar reA = /[-+]?(?:\\d+\\.?\\d*|\\.?\\d+)(?:[eE][-+]?\\d+)?/g,\n reB = new RegExp(reA.source, \"g\");\n\nfunction zero(b) {\n return function() {\n return b;\n };\n}\n\nfunction one(b) {\n return function(t) {\n return b(t) + \"\";\n };\n}\n\nexport default function(a, b) {\n var bi = reA.lastIndex = reB.lastIndex = 0, // scan index for next number in b\n am, // current match in a\n bm, // current match in b\n bs, // string preceding current number in b, if any\n i = -1, // index in s\n s = [], // string constants and placeholders\n q = []; // number interpolators\n\n // Coerce inputs to strings.\n a = a + \"\", b = b + \"\";\n\n // Interpolate pairs of numbers in a & b.\n while ((am = reA.exec(a))\n && (bm = reB.exec(b))) {\n if ((bs = bm.index) > bi) { // a string precedes the next number in b\n bs = b.slice(bi, bs);\n if (s[i]) s[i] += bs; // coalesce with previous string\n else s[++i] = bs;\n }\n if ((am = am[0]) === (bm = bm[0])) { // numbers in a & b match\n if (s[i]) s[i] += bm; // coalesce with previous string\n else s[++i] = bm;\n } else { // interpolate non-matching numbers\n s[++i] = null;\n q.push({i: i, x: number(am, bm)});\n }\n bi = reB.lastIndex;\n }\n\n // Add remains of b.\n if (bi < b.length) {\n bs = b.slice(bi);\n if (s[i]) s[i] += bs; // coalesce with previous string\n else s[++i] = bs;\n }\n\n // Special optimization for only a single match.\n // Otherwise, interpolate each of the numbers and rejoin the string.\n return s.length < 2 ? (q[0]\n ? one(q[0].x)\n : zero(b))\n : (b = q.length, function(t) {\n for (var i = 0, o; i < b; ++i) s[(o = q[i]).i] = o.x(t);\n return s.join(\"\");\n });\n}\n","import value from \"./value.js\";\nimport numberArray, {isNumberArray} from \"./numberArray.js\";\n\nexport default function(a, b) {\n return (isNumberArray(b) ? numberArray : genericArray)(a, b);\n}\n\nexport function genericArray(a, b) {\n var nb = b ? b.length : 0,\n na = a ? Math.min(nb, a.length) : 0,\n x = new Array(na),\n c = new Array(nb),\n i;\n\n for (i = 0; i < na; ++i) x[i] = value(a[i], b[i]);\n for (; i < nb; ++i) c[i] = b[i];\n\n return function(t) {\n for (i = 0; i < na; ++i) c[i] = x[i](t);\n return c;\n };\n}\n","export default function(a, b) {\n var d = new Date;\n return a = +a, b = +b, function(t) {\n return d.setTime(a * (1 - t) + b * t), d;\n };\n}\n","import value from \"./value.js\";\n\nexport default function(a, b) {\n var i = {},\n c = {},\n k;\n\n if (a === null || typeof a !== \"object\") a = {};\n if (b === null || typeof b !== \"object\") b = {};\n\n for (k in b) {\n if (k in a) {\n i[k] = value(a[k], b[k]);\n } else {\n c[k] = b[k];\n }\n }\n\n return function(t) {\n for (k in i) c[k] = i[k](t);\n return c;\n };\n}\n","export default function(a, b) {\n if (!b) b = [];\n var n = a ? Math.min(b.length, a.length) : 0,\n c = b.slice(),\n i;\n return function(t) {\n for (i = 0; i < n; ++i) c[i] = a[i] * (1 - t) + b[i] * t;\n return c;\n };\n}\n\nexport function isNumberArray(x) {\n return ArrayBuffer.isView(x) && !(x instanceof DataView);\n}\n","import {color} from \"d3-color\";\nimport rgb from \"./rgb.js\";\nimport {genericArray} from \"./array.js\";\nimport date from \"./date.js\";\nimport number from \"./number.js\";\nimport object from \"./object.js\";\nimport string from \"./string.js\";\nimport constant from \"./constant.js\";\nimport numberArray, {isNumberArray} from \"./numberArray.js\";\n\nexport default function(a, b) {\n var t = typeof b, c;\n return b == null || t === \"boolean\" ? constant(b)\n : (t === \"number\" ? number\n : t === \"string\" ? ((c = color(b)) ? (b = c, rgb) : string)\n : b instanceof color ? rgb\n : b instanceof Date ? date\n : isNumberArray(b) ? numberArray\n : Array.isArray(b) ? genericArray\n : typeof b.valueOf !== \"function\" && typeof b.toString !== \"function\" || isNaN(b) ? object\n : number)(a, b);\n}\n","import {range as sequence} from \"d3-array\";\nimport {initRange} from \"./init.js\";\nimport ordinal from \"./ordinal.js\";\n\nexport default function band() {\n var scale = ordinal().unknown(undefined),\n domain = scale.domain,\n ordinalRange = scale.range,\n r0 = 0,\n r1 = 1,\n step,\n bandwidth,\n round = false,\n paddingInner = 0,\n paddingOuter = 0,\n align = 0.5;\n\n delete scale.unknown;\n\n function rescale() {\n var n = domain().length,\n reverse = r1 < r0,\n start = reverse ? r1 : r0,\n stop = reverse ? r0 : r1;\n step = (stop - start) / Math.max(1, n - paddingInner + paddingOuter * 2);\n if (round) step = Math.floor(step);\n start += (stop - start - step * (n - paddingInner)) * align;\n bandwidth = step * (1 - paddingInner);\n if (round) start = Math.round(start), bandwidth = Math.round(bandwidth);\n var values = sequence(n).map(function(i) { return start + step * i; });\n return ordinalRange(reverse ? values.reverse() : values);\n }\n\n scale.domain = function(_) {\n return arguments.length ? (domain(_), rescale()) : domain();\n };\n\n scale.range = function(_) {\n return arguments.length ? ([r0, r1] = _, r0 = +r0, r1 = +r1, rescale()) : [r0, r1];\n };\n\n scale.rangeRound = function(_) {\n return [r0, r1] = _, r0 = +r0, r1 = +r1, round = true, rescale();\n };\n\n scale.bandwidth = function() {\n return bandwidth;\n };\n\n scale.step = function() {\n return step;\n };\n\n scale.round = function(_) {\n return arguments.length ? (round = !!_, rescale()) : round;\n };\n\n scale.padding = function(_) {\n return arguments.length ? (paddingInner = Math.min(1, paddingOuter = +_), rescale()) : paddingInner;\n };\n\n scale.paddingInner = function(_) {\n return arguments.length ? (paddingInner = Math.min(1, _), rescale()) : paddingInner;\n };\n\n scale.paddingOuter = function(_) {\n return arguments.length ? (paddingOuter = +_, rescale()) : paddingOuter;\n };\n\n scale.align = function(_) {\n return arguments.length ? (align = Math.max(0, Math.min(1, _)), rescale()) : align;\n };\n\n scale.copy = function() {\n return band(domain(), [r0, r1])\n .round(round)\n .paddingInner(paddingInner)\n .paddingOuter(paddingOuter)\n .align(align);\n };\n\n return initRange.apply(rescale(), arguments);\n}\n\nfunction pointish(scale) {\n var copy = scale.copy;\n\n scale.padding = scale.paddingOuter;\n delete scale.paddingInner;\n delete scale.paddingOuter;\n\n scale.copy = function() {\n return pointish(copy());\n };\n\n return scale;\n}\n\nexport function point() {\n return pointish(band.apply(null, arguments).paddingInner(1));\n}\n","export default function range(start, stop, step) {\n start = +start, stop = +stop, step = (n = arguments.length) < 2 ? (stop = start, start = 0, 1) : n < 3 ? 1 : +step;\n\n var i = -1,\n n = Math.max(0, Math.ceil((stop - start) / step)) | 0,\n range = new Array(n);\n\n while (++i < n) {\n range[i] = start + i * step;\n }\n\n return range;\n}\n","import {bisect} from \"d3-array\";\nimport {interpolate as interpolateValue, interpolateNumber, interpolateRound} from \"d3-interpolate\";\nimport constant from \"./constant.js\";\nimport number from \"./number.js\";\n\nvar unit = [0, 1];\n\nexport function identity(x) {\n return x;\n}\n\nfunction normalize(a, b) {\n return (b -= (a = +a))\n ? function(x) { return (x - a) / b; }\n : constant(isNaN(b) ? NaN : 0.5);\n}\n\nfunction clamper(a, b) {\n var t;\n if (a > b) t = a, a = b, b = t;\n return function(x) { return Math.max(a, Math.min(b, x)); };\n}\n\n// normalize(a, b)(x) takes a domain value x in [a,b] and returns the corresponding parameter t in [0,1].\n// interpolate(a, b)(t) takes a parameter t in [0,1] and returns the corresponding range value x in [a,b].\nfunction bimap(domain, range, interpolate) {\n var d0 = domain[0], d1 = domain[1], r0 = range[0], r1 = range[1];\n if (d1 < d0) d0 = normalize(d1, d0), r0 = interpolate(r1, r0);\n else d0 = normalize(d0, d1), r0 = interpolate(r0, r1);\n return function(x) { return r0(d0(x)); };\n}\n\nfunction polymap(domain, range, interpolate) {\n var j = Math.min(domain.length, range.length) - 1,\n d = new Array(j),\n r = new Array(j),\n i = -1;\n\n // Reverse descending domains.\n if (domain[j] < domain[0]) {\n domain = domain.slice().reverse();\n range = range.slice().reverse();\n }\n\n while (++i < j) {\n d[i] = normalize(domain[i], domain[i + 1]);\n r[i] = interpolate(range[i], range[i + 1]);\n }\n\n return function(x) {\n var i = bisect(domain, x, 1, j) - 1;\n return r[i](d[i](x));\n };\n}\n\nexport function copy(source, target) {\n return target\n .domain(source.domain())\n .range(source.range())\n .interpolate(source.interpolate())\n .clamp(source.clamp())\n .unknown(source.unknown());\n}\n\nexport function transformer() {\n var domain = unit,\n range = unit,\n interpolate = interpolateValue,\n transform,\n untransform,\n unknown,\n clamp = identity,\n piecewise,\n output,\n input;\n\n function rescale() {\n var n = Math.min(domain.length, range.length);\n if (clamp !== identity) clamp = clamper(domain[0], domain[n - 1]);\n piecewise = n > 2 ? polymap : bimap;\n output = input = null;\n return scale;\n }\n\n function scale(x) {\n return x == null || isNaN(x = +x) ? unknown : (output || (output = piecewise(domain.map(transform), range, interpolate)))(transform(clamp(x)));\n }\n\n scale.invert = function(y) {\n return clamp(untransform((input || (input = piecewise(range, domain.map(transform), interpolateNumber)))(y)));\n };\n\n scale.domain = function(_) {\n return arguments.length ? (domain = Array.from(_, number), rescale()) : domain.slice();\n };\n\n scale.range = function(_) {\n return arguments.length ? (range = Array.from(_), rescale()) : range.slice();\n };\n\n scale.rangeRound = function(_) {\n return range = Array.from(_), interpolate = interpolateRound, rescale();\n };\n\n scale.clamp = function(_) {\n return arguments.length ? (clamp = _ ? true : identity, rescale()) : clamp !== identity;\n };\n\n scale.interpolate = function(_) {\n return arguments.length ? (interpolate = _, rescale()) : interpolate;\n };\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : unknown;\n };\n\n return function(t, u) {\n transform = t, untransform = u;\n return rescale();\n };\n}\n\nexport default function continuous() {\n return transformer()(identity, identity);\n}\n","export default function constants(x) {\n return function() {\n return x;\n };\n}\n","import {linearish} from \"./linear.js\";\nimport number from \"./number.js\";\n\nexport default function identity(domain) {\n var unknown;\n\n function scale(x) {\n return x == null || isNaN(x = +x) ? unknown : x;\n }\n\n scale.invert = scale;\n\n scale.domain = scale.range = function(_) {\n return arguments.length ? (domain = Array.from(_, number), scale) : domain.slice();\n };\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : unknown;\n };\n\n scale.copy = function() {\n return identity(domain).unknown(unknown);\n };\n\n domain = arguments.length ? Array.from(domain, number) : [0, 1];\n\n return linearish(scale);\n}\n","export default function nice(domain, interval) {\n domain = domain.slice();\n\n var i0 = 0,\n i1 = domain.length - 1,\n x0 = domain[i0],\n x1 = domain[i1],\n t;\n\n if (x1 < x0) {\n t = i0, i0 = i1, i1 = t;\n t = x0, x0 = x1, x1 = t;\n }\n\n domain[i0] = interval.floor(x0);\n domain[i1] = interval.ceil(x1);\n return domain;\n}\n","import {ticks} from \"d3-array\";\nimport {format, formatSpecifier} from \"d3-format\";\nimport nice from \"./nice.js\";\nimport {copy, transformer} from \"./continuous.js\";\nimport {initRange} from \"./init.js\";\n\nfunction transformLog(x) {\n return Math.log(x);\n}\n\nfunction transformExp(x) {\n return Math.exp(x);\n}\n\nfunction transformLogn(x) {\n return -Math.log(-x);\n}\n\nfunction transformExpn(x) {\n return -Math.exp(-x);\n}\n\nfunction pow10(x) {\n return isFinite(x) ? +(\"1e\" + x) : x < 0 ? 0 : x;\n}\n\nfunction powp(base) {\n return base === 10 ? pow10\n : base === Math.E ? Math.exp\n : x => Math.pow(base, x);\n}\n\nfunction logp(base) {\n return base === Math.E ? Math.log\n : base === 10 && Math.log10\n || base === 2 && Math.log2\n || (base = Math.log(base), x => Math.log(x) / base);\n}\n\nfunction reflect(f) {\n return (x, k) => -f(-x, k);\n}\n\nexport function loggish(transform) {\n const scale = transform(transformLog, transformExp);\n const domain = scale.domain;\n let base = 10;\n let logs;\n let pows;\n\n function rescale() {\n logs = logp(base), pows = powp(base);\n if (domain()[0] < 0) {\n logs = reflect(logs), pows = reflect(pows);\n transform(transformLogn, transformExpn);\n } else {\n transform(transformLog, transformExp);\n }\n return scale;\n }\n\n scale.base = function(_) {\n return arguments.length ? (base = +_, rescale()) : base;\n };\n\n scale.domain = function(_) {\n return arguments.length ? (domain(_), rescale()) : domain();\n };\n\n scale.ticks = count => {\n const d = domain();\n let u = d[0];\n let v = d[d.length - 1];\n const r = v < u;\n\n if (r) ([u, v] = [v, u]);\n\n let i = logs(u);\n let j = logs(v);\n let k;\n let t;\n const n = count == null ? 10 : +count;\n let z = [];\n\n if (!(base % 1) && j - i < n) {\n i = Math.floor(i), j = Math.ceil(j);\n if (u > 0) for (; i <= j; ++i) {\n for (k = 1; k < base; ++k) {\n t = i < 0 ? k / pows(-i) : k * pows(i);\n if (t < u) continue;\n if (t > v) break;\n z.push(t);\n }\n } else for (; i <= j; ++i) {\n for (k = base - 1; k >= 1; --k) {\n t = i > 0 ? k / pows(-i) : k * pows(i);\n if (t < u) continue;\n if (t > v) break;\n z.push(t);\n }\n }\n if (z.length * 2 < n) z = ticks(u, v, n);\n } else {\n z = ticks(i, j, Math.min(j - i, n)).map(pows);\n }\n return r ? z.reverse() : z;\n };\n\n scale.tickFormat = (count, specifier) => {\n if (count == null) count = 10;\n if (specifier == null) specifier = base === 10 ? \"s\" : \",\";\n if (typeof specifier !== \"function\") {\n if (!(base % 1) && (specifier = formatSpecifier(specifier)).precision == null) specifier.trim = true;\n specifier = format(specifier);\n }\n if (count === Infinity) return specifier;\n const k = Math.max(1, base * count / scale.ticks().length); // TODO fast estimate?\n return d => {\n let i = d / pows(Math.round(logs(d)));\n if (i * base < base - 0.5) i *= base;\n return i <= k ? specifier(d) : \"\";\n };\n };\n\n scale.nice = () => {\n return domain(nice(domain(), {\n floor: x => pows(Math.floor(logs(x))),\n ceil: x => pows(Math.ceil(logs(x)))\n }));\n };\n\n return scale;\n}\n\nexport default function log() {\n const scale = loggish(transformer()).domain([1, 10]);\n scale.copy = () => copy(scale, log()).base(scale.base());\n initRange.apply(scale, arguments);\n return scale;\n}\n","import {linearish} from \"./linear.js\";\nimport {copy, transformer} from \"./continuous.js\";\nimport {initRange} from \"./init.js\";\n\nfunction transformSymlog(c) {\n return function(x) {\n return Math.sign(x) * Math.log1p(Math.abs(x / c));\n };\n}\n\nfunction transformSymexp(c) {\n return function(x) {\n return Math.sign(x) * Math.expm1(Math.abs(x)) * c;\n };\n}\n\nexport function symlogish(transform) {\n var c = 1, scale = transform(transformSymlog(c), transformSymexp(c));\n\n scale.constant = function(_) {\n return arguments.length ? transform(transformSymlog(c = +_), transformSymexp(c)) : c;\n };\n\n return linearish(scale);\n}\n\nexport default function symlog() {\n var scale = symlogish(transformer());\n\n scale.copy = function() {\n return copy(scale, symlog()).constant(scale.constant());\n };\n\n return initRange.apply(scale, arguments);\n}\n","import {linearish} from \"./linear.js\";\nimport {copy, identity, transformer} from \"./continuous.js\";\nimport {initRange} from \"./init.js\";\n\nfunction transformPow(exponent) {\n return function(x) {\n return x < 0 ? -Math.pow(-x, exponent) : Math.pow(x, exponent);\n };\n}\n\nfunction transformSqrt(x) {\n return x < 0 ? -Math.sqrt(-x) : Math.sqrt(x);\n}\n\nfunction transformSquare(x) {\n return x < 0 ? -x * x : x * x;\n}\n\nexport function powish(transform) {\n var scale = transform(identity, identity),\n exponent = 1;\n\n function rescale() {\n return exponent === 1 ? transform(identity, identity)\n : exponent === 0.5 ? transform(transformSqrt, transformSquare)\n : transform(transformPow(exponent), transformPow(1 / exponent));\n }\n\n scale.exponent = function(_) {\n return arguments.length ? (exponent = +_, rescale()) : exponent;\n };\n\n return linearish(scale);\n}\n\nexport default function pow() {\n var scale = powish(transformer());\n\n scale.copy = function() {\n return copy(scale, pow()).exponent(scale.exponent());\n };\n\n initRange.apply(scale, arguments);\n\n return scale;\n}\n\nexport function sqrt() {\n return pow.apply(null, arguments).exponent(0.5);\n}\n","import continuous from \"./continuous.js\";\nimport {initRange} from \"./init.js\";\nimport {linearish} from \"./linear.js\";\nimport number from \"./number.js\";\n\nfunction square(x) {\n return Math.sign(x) * x * x;\n}\n\nfunction unsquare(x) {\n return Math.sign(x) * Math.sqrt(Math.abs(x));\n}\n\nexport default function radial() {\n var squared = continuous(),\n range = [0, 1],\n round = false,\n unknown;\n\n function scale(x) {\n var y = unsquare(squared(x));\n return isNaN(y) ? unknown : round ? Math.round(y) : y;\n }\n\n scale.invert = function(y) {\n return squared.invert(square(y));\n };\n\n scale.domain = function(_) {\n return arguments.length ? (squared.domain(_), scale) : squared.domain();\n };\n\n scale.range = function(_) {\n return arguments.length ? (squared.range((range = Array.from(_, number)).map(square)), scale) : range.slice();\n };\n\n scale.rangeRound = function(_) {\n return scale.range(_).round(true);\n };\n\n scale.round = function(_) {\n return arguments.length ? (round = !!_, scale) : round;\n };\n\n scale.clamp = function(_) {\n return arguments.length ? (squared.clamp(_), scale) : squared.clamp();\n };\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : unknown;\n };\n\n scale.copy = function() {\n return radial(squared.domain(), range)\n .round(round)\n .clamp(squared.clamp())\n .unknown(unknown);\n };\n\n initRange.apply(scale, arguments);\n\n return linearish(scale);\n}\n","import ascending from \"./ascending.js\";\nimport permute from \"./permute.js\";\n\nexport default function sort(values, ...F) {\n if (typeof values[Symbol.iterator] !== \"function\") throw new TypeError(\"values is not iterable\");\n values = Array.from(values);\n let [f] = F;\n if ((f && f.length !== 2) || F.length > 1) {\n const index = Uint32Array.from(values, (d, i) => i);\n if (F.length > 1) {\n F = F.map(f => values.map(f));\n index.sort((i, j) => {\n for (const f of F) {\n const c = ascendingDefined(f[i], f[j]);\n if (c) return c;\n }\n });\n } else {\n f = values.map(f);\n index.sort((i, j) => ascendingDefined(f[i], f[j]));\n }\n return permute(values, index);\n }\n return values.sort(compareDefined(f));\n}\n\nexport function compareDefined(compare = ascending) {\n if (compare === ascending) return ascendingDefined;\n if (typeof compare !== \"function\") throw new TypeError(\"compare is not a function\");\n return (a, b) => {\n const x = compare(a, b);\n if (x || x === 0) return x;\n return (compare(b, b) === 0) - (compare(a, a) === 0);\n };\n}\n\nexport function ascendingDefined(a, b) {\n return (a == null || !(a >= a)) - (b == null || !(b >= b)) || (a < b ? -1 : a > b ? 1 : 0);\n}\n","import {ascendingDefined, compareDefined} from \"./sort.js\";\n\n// Based on https://github.com/mourner/quickselect\n// ISC license, Copyright 2018 Vladimir Agafonkin.\nexport default function quickselect(array, k, left = 0, right = array.length - 1, compare) {\n compare = compare === undefined ? ascendingDefined : compareDefined(compare);\n\n while (right > left) {\n if (right - left > 600) {\n const n = right - left + 1;\n const m = k - left + 1;\n const z = Math.log(n);\n const s = 0.5 * Math.exp(2 * z / 3);\n const sd = 0.5 * Math.sqrt(z * s * (n - s) / n) * (m - n / 2 < 0 ? -1 : 1);\n const newLeft = Math.max(left, Math.floor(k - m * s / n + sd));\n const newRight = Math.min(right, Math.floor(k + (n - m) * s / n + sd));\n quickselect(array, k, newLeft, newRight, compare);\n }\n\n const t = array[k];\n let i = left;\n let j = right;\n\n swap(array, left, k);\n if (compare(array[right], t) > 0) swap(array, left, right);\n\n while (i < j) {\n swap(array, i, j), ++i, --j;\n while (compare(array[i], t) < 0) ++i;\n while (compare(array[j], t) > 0) --j;\n }\n\n if (compare(array[left], t) === 0) swap(array, left, j);\n else ++j, swap(array, j, right);\n\n if (j <= k) left = j + 1;\n if (k <= j) right = j - 1;\n }\n\n return array;\n}\n\nfunction swap(array, i, j) {\n const t = array[i];\n array[i] = array[j];\n array[j] = t;\n}\n","import max from \"./max.js\";\nimport maxIndex from \"./maxIndex.js\";\nimport min from \"./min.js\";\nimport minIndex from \"./minIndex.js\";\nimport quickselect from \"./quickselect.js\";\nimport number, {numbers} from \"./number.js\";\nimport {ascendingDefined} from \"./sort.js\";\nimport greatest from \"./greatest.js\";\n\nexport default function quantile(values, p, valueof) {\n values = Float64Array.from(numbers(values, valueof));\n if (!(n = values.length)) return;\n if ((p = +p) <= 0 || n < 2) return min(values);\n if (p >= 1) return max(values);\n var n,\n i = (n - 1) * p,\n i0 = Math.floor(i),\n value0 = max(quickselect(values, i0).subarray(0, i0 + 1)),\n value1 = min(values.subarray(i0 + 1));\n return value0 + (value1 - value0) * (i - i0);\n}\n\nexport function quantileSorted(values, p, valueof = number) {\n if (!(n = values.length)) return;\n if ((p = +p) <= 0 || n < 2) return +valueof(values[0], 0, values);\n if (p >= 1) return +valueof(values[n - 1], n - 1, values);\n var n,\n i = (n - 1) * p,\n i0 = Math.floor(i),\n value0 = +valueof(values[i0], i0, values),\n value1 = +valueof(values[i0 + 1], i0 + 1, values);\n return value0 + (value1 - value0) * (i - i0);\n}\n\nexport function quantileIndex(values, p, valueof) {\n values = Float64Array.from(numbers(values, valueof));\n if (!(n = values.length)) return;\n if ((p = +p) <= 0 || n < 2) return minIndex(values);\n if (p >= 1) return maxIndex(values);\n var n,\n i = Math.floor((n - 1) * p),\n order = (i, j) => ascendingDefined(values[i], values[j]),\n index = quickselect(Uint32Array.from(values, (_, i) => i), i, 0, n - 1, order);\n return greatest(index.subarray(0, i + 1), i => values[i]);\n}\n","import {ascending, bisect, quantileSorted as threshold} from \"d3-array\";\nimport {initRange} from \"./init.js\";\n\nexport default function quantile() {\n var domain = [],\n range = [],\n thresholds = [],\n unknown;\n\n function rescale() {\n var i = 0, n = Math.max(1, range.length);\n thresholds = new Array(n - 1);\n while (++i < n) thresholds[i - 1] = threshold(domain, i / n);\n return scale;\n }\n\n function scale(x) {\n return x == null || isNaN(x = +x) ? unknown : range[bisect(thresholds, x)];\n }\n\n scale.invertExtent = function(y) {\n var i = range.indexOf(y);\n return i < 0 ? [NaN, NaN] : [\n i > 0 ? thresholds[i - 1] : domain[0],\n i < thresholds.length ? thresholds[i] : domain[domain.length - 1]\n ];\n };\n\n scale.domain = function(_) {\n if (!arguments.length) return domain.slice();\n domain = [];\n for (let d of _) if (d != null && !isNaN(d = +d)) domain.push(d);\n domain.sort(ascending);\n return rescale();\n };\n\n scale.range = function(_) {\n return arguments.length ? (range = Array.from(_), rescale()) : range.slice();\n };\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : unknown;\n };\n\n scale.quantiles = function() {\n return thresholds.slice();\n };\n\n scale.copy = function() {\n return quantile()\n .domain(domain)\n .range(range)\n .unknown(unknown);\n };\n\n return initRange.apply(scale, arguments);\n}\n","import {bisect} from \"d3-array\";\nimport {linearish} from \"./linear.js\";\nimport {initRange} from \"./init.js\";\n\nexport default function quantize() {\n var x0 = 0,\n x1 = 1,\n n = 1,\n domain = [0.5],\n range = [0, 1],\n unknown;\n\n function scale(x) {\n return x != null && x <= x ? range[bisect(domain, x, 0, n)] : unknown;\n }\n\n function rescale() {\n var i = -1;\n domain = new Array(n);\n while (++i < n) domain[i] = ((i + 1) * x1 - (i - n) * x0) / (n + 1);\n return scale;\n }\n\n scale.domain = function(_) {\n return arguments.length ? ([x0, x1] = _, x0 = +x0, x1 = +x1, rescale()) : [x0, x1];\n };\n\n scale.range = function(_) {\n return arguments.length ? (n = (range = Array.from(_)).length - 1, rescale()) : range.slice();\n };\n\n scale.invertExtent = function(y) {\n var i = range.indexOf(y);\n return i < 0 ? [NaN, NaN]\n : i < 1 ? [x0, domain[0]]\n : i >= n ? [domain[n - 1], x1]\n : [domain[i - 1], domain[i]];\n };\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : scale;\n };\n\n scale.thresholds = function() {\n return domain.slice();\n };\n\n scale.copy = function() {\n return quantize()\n .domain([x0, x1])\n .range(range)\n .unknown(unknown);\n };\n\n return initRange.apply(linearish(scale), arguments);\n}\n","import {bisect} from \"d3-array\";\nimport {initRange} from \"./init.js\";\n\nexport default function threshold() {\n var domain = [0.5],\n range = [0, 1],\n unknown,\n n = 1;\n\n function scale(x) {\n return x != null && x <= x ? range[bisect(domain, x, 0, n)] : unknown;\n }\n\n scale.domain = function(_) {\n return arguments.length ? (domain = Array.from(_), n = Math.min(domain.length, range.length - 1), scale) : domain.slice();\n };\n\n scale.range = function(_) {\n return arguments.length ? (range = Array.from(_), n = Math.min(domain.length, range.length - 1), scale) : range.slice();\n };\n\n scale.invertExtent = function(y) {\n var i = range.indexOf(y);\n return [domain[i - 1], domain[i]];\n };\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : unknown;\n };\n\n scale.copy = function() {\n return threshold()\n .domain(domain)\n .range(range)\n .unknown(unknown);\n };\n\n return initRange.apply(scale, arguments);\n}\n","export const durationSecond = 1000;\nexport const durationMinute = durationSecond * 60;\nexport const durationHour = durationMinute * 60;\nexport const durationDay = durationHour * 24;\nexport const durationWeek = durationDay * 7;\nexport const durationMonth = durationDay * 30;\nexport const durationYear = durationDay * 365;\n","var t0 = new Date,\n t1 = new Date;\n\nexport default function newInterval(floori, offseti, count, field) {\n\n function interval(date) {\n return floori(date = arguments.length === 0 ? new Date : new Date(+date)), date;\n }\n\n interval.floor = function(date) {\n return floori(date = new Date(+date)), date;\n };\n\n interval.ceil = function(date) {\n return floori(date = new Date(date - 1)), offseti(date, 1), floori(date), date;\n };\n\n interval.round = function(date) {\n var d0 = interval(date),\n d1 = interval.ceil(date);\n return date - d0 < d1 - date ? d0 : d1;\n };\n\n interval.offset = function(date, step) {\n return offseti(date = new Date(+date), step == null ? 1 : Math.floor(step)), date;\n };\n\n interval.range = function(start, stop, step) {\n var range = [], previous;\n start = interval.ceil(start);\n step = step == null ? 1 : Math.floor(step);\n if (!(start < stop) || !(step > 0)) return range; // also handles Invalid Date\n do range.push(previous = new Date(+start)), offseti(start, step), floori(start);\n while (previous < start && start < stop);\n return range;\n };\n\n interval.filter = function(test) {\n return newInterval(function(date) {\n if (date >= date) while (floori(date), !test(date)) date.setTime(date - 1);\n }, function(date, step) {\n if (date >= date) {\n if (step < 0) while (++step <= 0) {\n while (offseti(date, -1), !test(date)) {} // eslint-disable-line no-empty\n } else while (--step >= 0) {\n while (offseti(date, +1), !test(date)) {} // eslint-disable-line no-empty\n }\n }\n });\n };\n\n if (count) {\n interval.count = function(start, end) {\n t0.setTime(+start), t1.setTime(+end);\n floori(t0), floori(t1);\n return Math.floor(count(t0, t1));\n };\n\n interval.every = function(step) {\n step = Math.floor(step);\n return !isFinite(step) || !(step > 0) ? null\n : !(step > 1) ? interval\n : interval.filter(field\n ? function(d) { return field(d) % step === 0; }\n : function(d) { return interval.count(0, d) % step === 0; });\n };\n }\n\n return interval;\n}\n","import interval from \"./interval.js\";\n\nvar millisecond = interval(function() {\n // noop\n}, function(date, step) {\n date.setTime(+date + step);\n}, function(start, end) {\n return end - start;\n});\n\n// An optimized implementation for this simple case.\nmillisecond.every = function(k) {\n k = Math.floor(k);\n if (!isFinite(k) || !(k > 0)) return null;\n if (!(k > 1)) return millisecond;\n return interval(function(date) {\n date.setTime(Math.floor(date / k) * k);\n }, function(date, step) {\n date.setTime(+date + step * k);\n }, function(start, end) {\n return (end - start) / k;\n });\n};\n\nexport default millisecond;\nexport var milliseconds = millisecond.range;\n","import interval from \"./interval.js\";\nimport {durationSecond} from \"./duration.js\";\n\nvar second = interval(function(date) {\n date.setTime(date - date.getMilliseconds());\n}, function(date, step) {\n date.setTime(+date + step * durationSecond);\n}, function(start, end) {\n return (end - start) / durationSecond;\n}, function(date) {\n return date.getUTCSeconds();\n});\n\nexport default second;\nexport var seconds = second.range;\n","import interval from \"./interval.js\";\nimport {durationMinute, durationSecond} from \"./duration.js\";\n\nvar minute = interval(function(date) {\n date.setTime(date - date.getMilliseconds() - date.getSeconds() * durationSecond);\n}, function(date, step) {\n date.setTime(+date + step * durationMinute);\n}, function(start, end) {\n return (end - start) / durationMinute;\n}, function(date) {\n return date.getMinutes();\n});\n\nexport default minute;\nexport var minutes = minute.range;\n","import interval from \"./interval.js\";\nimport {durationHour, durationMinute, durationSecond} from \"./duration.js\";\n\nvar hour = interval(function(date) {\n date.setTime(date - date.getMilliseconds() - date.getSeconds() * durationSecond - date.getMinutes() * durationMinute);\n}, function(date, step) {\n date.setTime(+date + step * durationHour);\n}, function(start, end) {\n return (end - start) / durationHour;\n}, function(date) {\n return date.getHours();\n});\n\nexport default hour;\nexport var hours = hour.range;\n","import interval from \"./interval.js\";\nimport {durationDay, durationMinute} from \"./duration.js\";\n\nvar day = interval(\n date => date.setHours(0, 0, 0, 0),\n (date, step) => date.setDate(date.getDate() + step),\n (start, end) => (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute) / durationDay,\n date => date.getDate() - 1\n);\n\nexport default day;\nexport var days = day.range;\n","import interval from \"./interval.js\";\nimport {durationMinute, durationWeek} from \"./duration.js\";\n\nfunction weekday(i) {\n return interval(function(date) {\n date.setDate(date.getDate() - (date.getDay() + 7 - i) % 7);\n date.setHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setDate(date.getDate() + step * 7);\n }, function(start, end) {\n return (end - start - (end.getTimezoneOffset() - start.getTimezoneOffset()) * durationMinute) / durationWeek;\n });\n}\n\nexport var sunday = weekday(0);\nexport var monday = weekday(1);\nexport var tuesday = weekday(2);\nexport var wednesday = weekday(3);\nexport var thursday = weekday(4);\nexport var friday = weekday(5);\nexport var saturday = weekday(6);\n\nexport var sundays = sunday.range;\nexport var mondays = monday.range;\nexport var tuesdays = tuesday.range;\nexport var wednesdays = wednesday.range;\nexport var thursdays = thursday.range;\nexport var fridays = friday.range;\nexport var saturdays = saturday.range;\n","import interval from \"./interval.js\";\n\nvar month = interval(function(date) {\n date.setDate(1);\n date.setHours(0, 0, 0, 0);\n}, function(date, step) {\n date.setMonth(date.getMonth() + step);\n}, function(start, end) {\n return end.getMonth() - start.getMonth() + (end.getFullYear() - start.getFullYear()) * 12;\n}, function(date) {\n return date.getMonth();\n});\n\nexport default month;\nexport var months = month.range;\n","import interval from \"./interval.js\";\n\nvar year = interval(function(date) {\n date.setMonth(0, 1);\n date.setHours(0, 0, 0, 0);\n}, function(date, step) {\n date.setFullYear(date.getFullYear() + step);\n}, function(start, end) {\n return end.getFullYear() - start.getFullYear();\n}, function(date) {\n return date.getFullYear();\n});\n\n// An optimized implementation for this simple case.\nyear.every = function(k) {\n return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : interval(function(date) {\n date.setFullYear(Math.floor(date.getFullYear() / k) * k);\n date.setMonth(0, 1);\n date.setHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setFullYear(date.getFullYear() + step * k);\n });\n};\n\nexport default year;\nexport var years = year.range;\n","import interval from \"./interval.js\";\nimport {durationMinute} from \"./duration.js\";\n\nvar utcMinute = interval(function(date) {\n date.setUTCSeconds(0, 0);\n}, function(date, step) {\n date.setTime(+date + step * durationMinute);\n}, function(start, end) {\n return (end - start) / durationMinute;\n}, function(date) {\n return date.getUTCMinutes();\n});\n\nexport default utcMinute;\nexport var utcMinutes = utcMinute.range;\n","import interval from \"./interval.js\";\nimport {durationHour} from \"./duration.js\";\n\nvar utcHour = interval(function(date) {\n date.setUTCMinutes(0, 0, 0);\n}, function(date, step) {\n date.setTime(+date + step * durationHour);\n}, function(start, end) {\n return (end - start) / durationHour;\n}, function(date) {\n return date.getUTCHours();\n});\n\nexport default utcHour;\nexport var utcHours = utcHour.range;\n","import interval from \"./interval.js\";\nimport {durationDay} from \"./duration.js\";\n\nvar utcDay = interval(function(date) {\n date.setUTCHours(0, 0, 0, 0);\n}, function(date, step) {\n date.setUTCDate(date.getUTCDate() + step);\n}, function(start, end) {\n return (end - start) / durationDay;\n}, function(date) {\n return date.getUTCDate() - 1;\n});\n\nexport default utcDay;\nexport var utcDays = utcDay.range;\n","import interval from \"./interval.js\";\nimport {durationWeek} from \"./duration.js\";\n\nfunction utcWeekday(i) {\n return interval(function(date) {\n date.setUTCDate(date.getUTCDate() - (date.getUTCDay() + 7 - i) % 7);\n date.setUTCHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setUTCDate(date.getUTCDate() + step * 7);\n }, function(start, end) {\n return (end - start) / durationWeek;\n });\n}\n\nexport var utcSunday = utcWeekday(0);\nexport var utcMonday = utcWeekday(1);\nexport var utcTuesday = utcWeekday(2);\nexport var utcWednesday = utcWeekday(3);\nexport var utcThursday = utcWeekday(4);\nexport var utcFriday = utcWeekday(5);\nexport var utcSaturday = utcWeekday(6);\n\nexport var utcSundays = utcSunday.range;\nexport var utcMondays = utcMonday.range;\nexport var utcTuesdays = utcTuesday.range;\nexport var utcWednesdays = utcWednesday.range;\nexport var utcThursdays = utcThursday.range;\nexport var utcFridays = utcFriday.range;\nexport var utcSaturdays = utcSaturday.range;\n","import interval from \"./interval.js\";\n\nvar utcMonth = interval(function(date) {\n date.setUTCDate(1);\n date.setUTCHours(0, 0, 0, 0);\n}, function(date, step) {\n date.setUTCMonth(date.getUTCMonth() + step);\n}, function(start, end) {\n return end.getUTCMonth() - start.getUTCMonth() + (end.getUTCFullYear() - start.getUTCFullYear()) * 12;\n}, function(date) {\n return date.getUTCMonth();\n});\n\nexport default utcMonth;\nexport var utcMonths = utcMonth.range;\n","import interval from \"./interval.js\";\n\nvar utcYear = interval(function(date) {\n date.setUTCMonth(0, 1);\n date.setUTCHours(0, 0, 0, 0);\n}, function(date, step) {\n date.setUTCFullYear(date.getUTCFullYear() + step);\n}, function(start, end) {\n return end.getUTCFullYear() - start.getUTCFullYear();\n}, function(date) {\n return date.getUTCFullYear();\n});\n\n// An optimized implementation for this simple case.\nutcYear.every = function(k) {\n return !isFinite(k = Math.floor(k)) || !(k > 0) ? null : interval(function(date) {\n date.setUTCFullYear(Math.floor(date.getUTCFullYear() / k) * k);\n date.setUTCMonth(0, 1);\n date.setUTCHours(0, 0, 0, 0);\n }, function(date, step) {\n date.setUTCFullYear(date.getUTCFullYear() + step * k);\n });\n};\n\nexport default utcYear;\nexport var utcYears = utcYear.range;\n","import {bisector, tickStep} from \"d3-array\";\nimport {durationDay, durationHour, durationMinute, durationMonth, durationSecond, durationWeek, durationYear} from \"./duration.js\";\nimport millisecond from \"./millisecond.js\";\nimport second from \"./second.js\";\nimport minute from \"./minute.js\";\nimport hour from \"./hour.js\";\nimport day from \"./day.js\";\nimport {sunday as week} from \"./week.js\";\nimport month from \"./month.js\";\nimport year from \"./year.js\";\nimport utcMinute from \"./utcMinute.js\";\nimport utcHour from \"./utcHour.js\";\nimport utcDay from \"./utcDay.js\";\nimport {utcSunday as utcWeek} from \"./utcWeek.js\";\nimport utcMonth from \"./utcMonth.js\";\nimport utcYear from \"./utcYear.js\";\n\nfunction ticker(year, month, week, day, hour, minute) {\n\n const tickIntervals = [\n [second, 1, durationSecond],\n [second, 5, 5 * durationSecond],\n [second, 15, 15 * durationSecond],\n [second, 30, 30 * durationSecond],\n [minute, 1, durationMinute],\n [minute, 5, 5 * durationMinute],\n [minute, 15, 15 * durationMinute],\n [minute, 30, 30 * durationMinute],\n [ hour, 1, durationHour ],\n [ hour, 3, 3 * durationHour ],\n [ hour, 6, 6 * durationHour ],\n [ hour, 12, 12 * durationHour ],\n [ day, 1, durationDay ],\n [ day, 2, 2 * durationDay ],\n [ week, 1, durationWeek ],\n [ month, 1, durationMonth ],\n [ month, 3, 3 * durationMonth ],\n [ year, 1, durationYear ]\n ];\n\n function ticks(start, stop, count) {\n const reverse = stop < start;\n if (reverse) [start, stop] = [stop, start];\n const interval = count && typeof count.range === \"function\" ? count : tickInterval(start, stop, count);\n const ticks = interval ? interval.range(start, +stop + 1) : []; // inclusive stop\n return reverse ? ticks.reverse() : ticks;\n }\n\n function tickInterval(start, stop, count) {\n const target = Math.abs(stop - start) / count;\n const i = bisector(([,, step]) => step).right(tickIntervals, target);\n if (i === tickIntervals.length) return year.every(tickStep(start / durationYear, stop / durationYear, count));\n if (i === 0) return millisecond.every(Math.max(tickStep(start, stop, count), 1));\n const [t, step] = tickIntervals[target / tickIntervals[i - 1][2] < tickIntervals[i][2] / target ? i - 1 : i];\n return t.every(step);\n }\n\n return [ticks, tickInterval];\n}\n\nconst [utcTicks, utcTickInterval] = ticker(utcYear, utcMonth, utcWeek, utcDay, utcHour, utcMinute);\nconst [timeTicks, timeTickInterval] = ticker(year, month, week, day, hour, minute);\n\nexport {utcTicks, utcTickInterval, timeTicks, timeTickInterval};\n","import {\n timeDay,\n timeSunday,\n timeMonday,\n timeThursday,\n timeYear,\n utcDay,\n utcSunday,\n utcMonday,\n utcThursday,\n utcYear\n} from \"d3-time\";\n\nfunction localDate(d) {\n if (0 <= d.y && d.y < 100) {\n var date = new Date(-1, d.m, d.d, d.H, d.M, d.S, d.L);\n date.setFullYear(d.y);\n return date;\n }\n return new Date(d.y, d.m, d.d, d.H, d.M, d.S, d.L);\n}\n\nfunction utcDate(d) {\n if (0 <= d.y && d.y < 100) {\n var date = new Date(Date.UTC(-1, d.m, d.d, d.H, d.M, d.S, d.L));\n date.setUTCFullYear(d.y);\n return date;\n }\n return new Date(Date.UTC(d.y, d.m, d.d, d.H, d.M, d.S, d.L));\n}\n\nfunction newDate(y, m, d) {\n return {y: y, m: m, d: d, H: 0, M: 0, S: 0, L: 0};\n}\n\nexport default function formatLocale(locale) {\n var locale_dateTime = locale.dateTime,\n locale_date = locale.date,\n locale_time = locale.time,\n locale_periods = locale.periods,\n locale_weekdays = locale.days,\n locale_shortWeekdays = locale.shortDays,\n locale_months = locale.months,\n locale_shortMonths = locale.shortMonths;\n\n var periodRe = formatRe(locale_periods),\n periodLookup = formatLookup(locale_periods),\n weekdayRe = formatRe(locale_weekdays),\n weekdayLookup = formatLookup(locale_weekdays),\n shortWeekdayRe = formatRe(locale_shortWeekdays),\n shortWeekdayLookup = formatLookup(locale_shortWeekdays),\n monthRe = formatRe(locale_months),\n monthLookup = formatLookup(locale_months),\n shortMonthRe = formatRe(locale_shortMonths),\n shortMonthLookup = formatLookup(locale_shortMonths);\n\n var formats = {\n \"a\": formatShortWeekday,\n \"A\": formatWeekday,\n \"b\": formatShortMonth,\n \"B\": formatMonth,\n \"c\": null,\n \"d\": formatDayOfMonth,\n \"e\": formatDayOfMonth,\n \"f\": formatMicroseconds,\n \"g\": formatYearISO,\n \"G\": formatFullYearISO,\n \"H\": formatHour24,\n \"I\": formatHour12,\n \"j\": formatDayOfYear,\n \"L\": formatMilliseconds,\n \"m\": formatMonthNumber,\n \"M\": formatMinutes,\n \"p\": formatPeriod,\n \"q\": formatQuarter,\n \"Q\": formatUnixTimestamp,\n \"s\": formatUnixTimestampSeconds,\n \"S\": formatSeconds,\n \"u\": formatWeekdayNumberMonday,\n \"U\": formatWeekNumberSunday,\n \"V\": formatWeekNumberISO,\n \"w\": formatWeekdayNumberSunday,\n \"W\": formatWeekNumberMonday,\n \"x\": null,\n \"X\": null,\n \"y\": formatYear,\n \"Y\": formatFullYear,\n \"Z\": formatZone,\n \"%\": formatLiteralPercent\n };\n\n var utcFormats = {\n \"a\": formatUTCShortWeekday,\n \"A\": formatUTCWeekday,\n \"b\": formatUTCShortMonth,\n \"B\": formatUTCMonth,\n \"c\": null,\n \"d\": formatUTCDayOfMonth,\n \"e\": formatUTCDayOfMonth,\n \"f\": formatUTCMicroseconds,\n \"g\": formatUTCYearISO,\n \"G\": formatUTCFullYearISO,\n \"H\": formatUTCHour24,\n \"I\": formatUTCHour12,\n \"j\": formatUTCDayOfYear,\n \"L\": formatUTCMilliseconds,\n \"m\": formatUTCMonthNumber,\n \"M\": formatUTCMinutes,\n \"p\": formatUTCPeriod,\n \"q\": formatUTCQuarter,\n \"Q\": formatUnixTimestamp,\n \"s\": formatUnixTimestampSeconds,\n \"S\": formatUTCSeconds,\n \"u\": formatUTCWeekdayNumberMonday,\n \"U\": formatUTCWeekNumberSunday,\n \"V\": formatUTCWeekNumberISO,\n \"w\": formatUTCWeekdayNumberSunday,\n \"W\": formatUTCWeekNumberMonday,\n \"x\": null,\n \"X\": null,\n \"y\": formatUTCYear,\n \"Y\": formatUTCFullYear,\n \"Z\": formatUTCZone,\n \"%\": formatLiteralPercent\n };\n\n var parses = {\n \"a\": parseShortWeekday,\n \"A\": parseWeekday,\n \"b\": parseShortMonth,\n \"B\": parseMonth,\n \"c\": parseLocaleDateTime,\n \"d\": parseDayOfMonth,\n \"e\": parseDayOfMonth,\n \"f\": parseMicroseconds,\n \"g\": parseYear,\n \"G\": parseFullYear,\n \"H\": parseHour24,\n \"I\": parseHour24,\n \"j\": parseDayOfYear,\n \"L\": parseMilliseconds,\n \"m\": parseMonthNumber,\n \"M\": parseMinutes,\n \"p\": parsePeriod,\n \"q\": parseQuarter,\n \"Q\": parseUnixTimestamp,\n \"s\": parseUnixTimestampSeconds,\n \"S\": parseSeconds,\n \"u\": parseWeekdayNumberMonday,\n \"U\": parseWeekNumberSunday,\n \"V\": parseWeekNumberISO,\n \"w\": parseWeekdayNumberSunday,\n \"W\": parseWeekNumberMonday,\n \"x\": parseLocaleDate,\n \"X\": parseLocaleTime,\n \"y\": parseYear,\n \"Y\": parseFullYear,\n \"Z\": parseZone,\n \"%\": parseLiteralPercent\n };\n\n // These recursive directive definitions must be deferred.\n formats.x = newFormat(locale_date, formats);\n formats.X = newFormat(locale_time, formats);\n formats.c = newFormat(locale_dateTime, formats);\n utcFormats.x = newFormat(locale_date, utcFormats);\n utcFormats.X = newFormat(locale_time, utcFormats);\n utcFormats.c = newFormat(locale_dateTime, utcFormats);\n\n function newFormat(specifier, formats) {\n return function(date) {\n var string = [],\n i = -1,\n j = 0,\n n = specifier.length,\n c,\n pad,\n format;\n\n if (!(date instanceof Date)) date = new Date(+date);\n\n while (++i < n) {\n if (specifier.charCodeAt(i) === 37) {\n string.push(specifier.slice(j, i));\n if ((pad = pads[c = specifier.charAt(++i)]) != null) c = specifier.charAt(++i);\n else pad = c === \"e\" ? \" \" : \"0\";\n if (format = formats[c]) c = format(date, pad);\n string.push(c);\n j = i + 1;\n }\n }\n\n string.push(specifier.slice(j, i));\n return string.join(\"\");\n };\n }\n\n function newParse(specifier, Z) {\n return function(string) {\n var d = newDate(1900, undefined, 1),\n i = parseSpecifier(d, specifier, string += \"\", 0),\n week, day;\n if (i != string.length) return null;\n\n // If a UNIX timestamp is specified, return it.\n if (\"Q\" in d) return new Date(d.Q);\n if (\"s\" in d) return new Date(d.s * 1000 + (\"L\" in d ? d.L : 0));\n\n // If this is utcParse, never use the local timezone.\n if (Z && !(\"Z\" in d)) d.Z = 0;\n\n // The am-pm flag is 0 for AM, and 1 for PM.\n if (\"p\" in d) d.H = d.H % 12 + d.p * 12;\n\n // If the month was not specified, inherit from the quarter.\n if (d.m === undefined) d.m = \"q\" in d ? d.q : 0;\n\n // Convert day-of-week and week-of-year to day-of-year.\n if (\"V\" in d) {\n if (d.V < 1 || d.V > 53) return null;\n if (!(\"w\" in d)) d.w = 1;\n if (\"Z\" in d) {\n week = utcDate(newDate(d.y, 0, 1)), day = week.getUTCDay();\n week = day > 4 || day === 0 ? utcMonday.ceil(week) : utcMonday(week);\n week = utcDay.offset(week, (d.V - 1) * 7);\n d.y = week.getUTCFullYear();\n d.m = week.getUTCMonth();\n d.d = week.getUTCDate() + (d.w + 6) % 7;\n } else {\n week = localDate(newDate(d.y, 0, 1)), day = week.getDay();\n week = day > 4 || day === 0 ? timeMonday.ceil(week) : timeMonday(week);\n week = timeDay.offset(week, (d.V - 1) * 7);\n d.y = week.getFullYear();\n d.m = week.getMonth();\n d.d = week.getDate() + (d.w + 6) % 7;\n }\n } else if (\"W\" in d || \"U\" in d) {\n if (!(\"w\" in d)) d.w = \"u\" in d ? d.u % 7 : \"W\" in d ? 1 : 0;\n day = \"Z\" in d ? utcDate(newDate(d.y, 0, 1)).getUTCDay() : localDate(newDate(d.y, 0, 1)).getDay();\n d.m = 0;\n d.d = \"W\" in d ? (d.w + 6) % 7 + d.W * 7 - (day + 5) % 7 : d.w + d.U * 7 - (day + 6) % 7;\n }\n\n // If a time zone is specified, all fields are interpreted as UTC and then\n // offset according to the specified time zone.\n if (\"Z\" in d) {\n d.H += d.Z / 100 | 0;\n d.M += d.Z % 100;\n return utcDate(d);\n }\n\n // Otherwise, all fields are in local time.\n return localDate(d);\n };\n }\n\n function parseSpecifier(d, specifier, string, j) {\n var i = 0,\n n = specifier.length,\n m = string.length,\n c,\n parse;\n\n while (i < n) {\n if (j >= m) return -1;\n c = specifier.charCodeAt(i++);\n if (c === 37) {\n c = specifier.charAt(i++);\n parse = parses[c in pads ? specifier.charAt(i++) : c];\n if (!parse || ((j = parse(d, string, j)) < 0)) return -1;\n } else if (c != string.charCodeAt(j++)) {\n return -1;\n }\n }\n\n return j;\n }\n\n function parsePeriod(d, string, i) {\n var n = periodRe.exec(string.slice(i));\n return n ? (d.p = periodLookup.get(n[0].toLowerCase()), i + n[0].length) : -1;\n }\n\n function parseShortWeekday(d, string, i) {\n var n = shortWeekdayRe.exec(string.slice(i));\n return n ? (d.w = shortWeekdayLookup.get(n[0].toLowerCase()), i + n[0].length) : -1;\n }\n\n function parseWeekday(d, string, i) {\n var n = weekdayRe.exec(string.slice(i));\n return n ? (d.w = weekdayLookup.get(n[0].toLowerCase()), i + n[0].length) : -1;\n }\n\n function parseShortMonth(d, string, i) {\n var n = shortMonthRe.exec(string.slice(i));\n return n ? (d.m = shortMonthLookup.get(n[0].toLowerCase()), i + n[0].length) : -1;\n }\n\n function parseMonth(d, string, i) {\n var n = monthRe.exec(string.slice(i));\n return n ? (d.m = monthLookup.get(n[0].toLowerCase()), i + n[0].length) : -1;\n }\n\n function parseLocaleDateTime(d, string, i) {\n return parseSpecifier(d, locale_dateTime, string, i);\n }\n\n function parseLocaleDate(d, string, i) {\n return parseSpecifier(d, locale_date, string, i);\n }\n\n function parseLocaleTime(d, string, i) {\n return parseSpecifier(d, locale_time, string, i);\n }\n\n function formatShortWeekday(d) {\n return locale_shortWeekdays[d.getDay()];\n }\n\n function formatWeekday(d) {\n return locale_weekdays[d.getDay()];\n }\n\n function formatShortMonth(d) {\n return locale_shortMonths[d.getMonth()];\n }\n\n function formatMonth(d) {\n return locale_months[d.getMonth()];\n }\n\n function formatPeriod(d) {\n return locale_periods[+(d.getHours() >= 12)];\n }\n\n function formatQuarter(d) {\n return 1 + ~~(d.getMonth() / 3);\n }\n\n function formatUTCShortWeekday(d) {\n return locale_shortWeekdays[d.getUTCDay()];\n }\n\n function formatUTCWeekday(d) {\n return locale_weekdays[d.getUTCDay()];\n }\n\n function formatUTCShortMonth(d) {\n return locale_shortMonths[d.getUTCMonth()];\n }\n\n function formatUTCMonth(d) {\n return locale_months[d.getUTCMonth()];\n }\n\n function formatUTCPeriod(d) {\n return locale_periods[+(d.getUTCHours() >= 12)];\n }\n\n function formatUTCQuarter(d) {\n return 1 + ~~(d.getUTCMonth() / 3);\n }\n\n return {\n format: function(specifier) {\n var f = newFormat(specifier += \"\", formats);\n f.toString = function() { return specifier; };\n return f;\n },\n parse: function(specifier) {\n var p = newParse(specifier += \"\", false);\n p.toString = function() { return specifier; };\n return p;\n },\n utcFormat: function(specifier) {\n var f = newFormat(specifier += \"\", utcFormats);\n f.toString = function() { return specifier; };\n return f;\n },\n utcParse: function(specifier) {\n var p = newParse(specifier += \"\", true);\n p.toString = function() { return specifier; };\n return p;\n }\n };\n}\n\nvar pads = {\"-\": \"\", \"_\": \" \", \"0\": \"0\"},\n numberRe = /^\\s*\\d+/, // note: ignores next directive\n percentRe = /^%/,\n requoteRe = /[\\\\^$*+?|[\\]().{}]/g;\n\nfunction pad(value, fill, width) {\n var sign = value < 0 ? \"-\" : \"\",\n string = (sign ? -value : value) + \"\",\n length = string.length;\n return sign + (length < width ? new Array(width - length + 1).join(fill) + string : string);\n}\n\nfunction requote(s) {\n return s.replace(requoteRe, \"\\\\$&\");\n}\n\nfunction formatRe(names) {\n return new RegExp(\"^(?:\" + names.map(requote).join(\"|\") + \")\", \"i\");\n}\n\nfunction formatLookup(names) {\n return new Map(names.map((name, i) => [name.toLowerCase(), i]));\n}\n\nfunction parseWeekdayNumberSunday(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 1));\n return n ? (d.w = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseWeekdayNumberMonday(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 1));\n return n ? (d.u = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseWeekNumberSunday(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.U = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseWeekNumberISO(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.V = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseWeekNumberMonday(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.W = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseFullYear(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 4));\n return n ? (d.y = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseYear(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.y = +n[0] + (+n[0] > 68 ? 1900 : 2000), i + n[0].length) : -1;\n}\n\nfunction parseZone(d, string, i) {\n var n = /^(Z)|([+-]\\d\\d)(?::?(\\d\\d))?/.exec(string.slice(i, i + 6));\n return n ? (d.Z = n[1] ? 0 : -(n[2] + (n[3] || \"00\")), i + n[0].length) : -1;\n}\n\nfunction parseQuarter(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 1));\n return n ? (d.q = n[0] * 3 - 3, i + n[0].length) : -1;\n}\n\nfunction parseMonthNumber(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.m = n[0] - 1, i + n[0].length) : -1;\n}\n\nfunction parseDayOfMonth(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.d = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseDayOfYear(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 3));\n return n ? (d.m = 0, d.d = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseHour24(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.H = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseMinutes(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.M = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseSeconds(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 2));\n return n ? (d.S = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseMilliseconds(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 3));\n return n ? (d.L = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseMicroseconds(d, string, i) {\n var n = numberRe.exec(string.slice(i, i + 6));\n return n ? (d.L = Math.floor(n[0] / 1000), i + n[0].length) : -1;\n}\n\nfunction parseLiteralPercent(d, string, i) {\n var n = percentRe.exec(string.slice(i, i + 1));\n return n ? i + n[0].length : -1;\n}\n\nfunction parseUnixTimestamp(d, string, i) {\n var n = numberRe.exec(string.slice(i));\n return n ? (d.Q = +n[0], i + n[0].length) : -1;\n}\n\nfunction parseUnixTimestampSeconds(d, string, i) {\n var n = numberRe.exec(string.slice(i));\n return n ? (d.s = +n[0], i + n[0].length) : -1;\n}\n\nfunction formatDayOfMonth(d, p) {\n return pad(d.getDate(), p, 2);\n}\n\nfunction formatHour24(d, p) {\n return pad(d.getHours(), p, 2);\n}\n\nfunction formatHour12(d, p) {\n return pad(d.getHours() % 12 || 12, p, 2);\n}\n\nfunction formatDayOfYear(d, p) {\n return pad(1 + timeDay.count(timeYear(d), d), p, 3);\n}\n\nfunction formatMilliseconds(d, p) {\n return pad(d.getMilliseconds(), p, 3);\n}\n\nfunction formatMicroseconds(d, p) {\n return formatMilliseconds(d, p) + \"000\";\n}\n\nfunction formatMonthNumber(d, p) {\n return pad(d.getMonth() + 1, p, 2);\n}\n\nfunction formatMinutes(d, p) {\n return pad(d.getMinutes(), p, 2);\n}\n\nfunction formatSeconds(d, p) {\n return pad(d.getSeconds(), p, 2);\n}\n\nfunction formatWeekdayNumberMonday(d) {\n var day = d.getDay();\n return day === 0 ? 7 : day;\n}\n\nfunction formatWeekNumberSunday(d, p) {\n return pad(timeSunday.count(timeYear(d) - 1, d), p, 2);\n}\n\nfunction dISO(d) {\n var day = d.getDay();\n return (day >= 4 || day === 0) ? timeThursday(d) : timeThursday.ceil(d);\n}\n\nfunction formatWeekNumberISO(d, p) {\n d = dISO(d);\n return pad(timeThursday.count(timeYear(d), d) + (timeYear(d).getDay() === 4), p, 2);\n}\n\nfunction formatWeekdayNumberSunday(d) {\n return d.getDay();\n}\n\nfunction formatWeekNumberMonday(d, p) {\n return pad(timeMonday.count(timeYear(d) - 1, d), p, 2);\n}\n\nfunction formatYear(d, p) {\n return pad(d.getFullYear() % 100, p, 2);\n}\n\nfunction formatYearISO(d, p) {\n d = dISO(d);\n return pad(d.getFullYear() % 100, p, 2);\n}\n\nfunction formatFullYear(d, p) {\n return pad(d.getFullYear() % 10000, p, 4);\n}\n\nfunction formatFullYearISO(d, p) {\n var day = d.getDay();\n d = (day >= 4 || day === 0) ? timeThursday(d) : timeThursday.ceil(d);\n return pad(d.getFullYear() % 10000, p, 4);\n}\n\nfunction formatZone(d) {\n var z = d.getTimezoneOffset();\n return (z > 0 ? \"-\" : (z *= -1, \"+\"))\n + pad(z / 60 | 0, \"0\", 2)\n + pad(z % 60, \"0\", 2);\n}\n\nfunction formatUTCDayOfMonth(d, p) {\n return pad(d.getUTCDate(), p, 2);\n}\n\nfunction formatUTCHour24(d, p) {\n return pad(d.getUTCHours(), p, 2);\n}\n\nfunction formatUTCHour12(d, p) {\n return pad(d.getUTCHours() % 12 || 12, p, 2);\n}\n\nfunction formatUTCDayOfYear(d, p) {\n return pad(1 + utcDay.count(utcYear(d), d), p, 3);\n}\n\nfunction formatUTCMilliseconds(d, p) {\n return pad(d.getUTCMilliseconds(), p, 3);\n}\n\nfunction formatUTCMicroseconds(d, p) {\n return formatUTCMilliseconds(d, p) + \"000\";\n}\n\nfunction formatUTCMonthNumber(d, p) {\n return pad(d.getUTCMonth() + 1, p, 2);\n}\n\nfunction formatUTCMinutes(d, p) {\n return pad(d.getUTCMinutes(), p, 2);\n}\n\nfunction formatUTCSeconds(d, p) {\n return pad(d.getUTCSeconds(), p, 2);\n}\n\nfunction formatUTCWeekdayNumberMonday(d) {\n var dow = d.getUTCDay();\n return dow === 0 ? 7 : dow;\n}\n\nfunction formatUTCWeekNumberSunday(d, p) {\n return pad(utcSunday.count(utcYear(d) - 1, d), p, 2);\n}\n\nfunction UTCdISO(d) {\n var day = d.getUTCDay();\n return (day >= 4 || day === 0) ? utcThursday(d) : utcThursday.ceil(d);\n}\n\nfunction formatUTCWeekNumberISO(d, p) {\n d = UTCdISO(d);\n return pad(utcThursday.count(utcYear(d), d) + (utcYear(d).getUTCDay() === 4), p, 2);\n}\n\nfunction formatUTCWeekdayNumberSunday(d) {\n return d.getUTCDay();\n}\n\nfunction formatUTCWeekNumberMonday(d, p) {\n return pad(utcMonday.count(utcYear(d) - 1, d), p, 2);\n}\n\nfunction formatUTCYear(d, p) {\n return pad(d.getUTCFullYear() % 100, p, 2);\n}\n\nfunction formatUTCYearISO(d, p) {\n d = UTCdISO(d);\n return pad(d.getUTCFullYear() % 100, p, 2);\n}\n\nfunction formatUTCFullYear(d, p) {\n return pad(d.getUTCFullYear() % 10000, p, 4);\n}\n\nfunction formatUTCFullYearISO(d, p) {\n var day = d.getUTCDay();\n d = (day >= 4 || day === 0) ? utcThursday(d) : utcThursday.ceil(d);\n return pad(d.getUTCFullYear() % 10000, p, 4);\n}\n\nfunction formatUTCZone() {\n return \"+0000\";\n}\n\nfunction formatLiteralPercent() {\n return \"%\";\n}\n\nfunction formatUnixTimestamp(d) {\n return +d;\n}\n\nfunction formatUnixTimestampSeconds(d) {\n return Math.floor(+d / 1000);\n}\n","import formatLocale from \"./locale.js\";\n\nvar locale;\nexport var timeFormat;\nexport var timeParse;\nexport var utcFormat;\nexport var utcParse;\n\ndefaultLocale({\n dateTime: \"%x, %X\",\n date: \"%-m/%-d/%Y\",\n time: \"%-I:%M:%S %p\",\n periods: [\"AM\", \"PM\"],\n days: [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\", \"Thursday\", \"Friday\", \"Saturday\"],\n shortDays: [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"],\n months: [\"January\", \"February\", \"March\", \"April\", \"May\", \"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"],\n shortMonths: [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\", \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"]\n});\n\nexport default function defaultLocale(definition) {\n locale = formatLocale(definition);\n timeFormat = locale.format;\n timeParse = locale.parse;\n utcFormat = locale.utcFormat;\n utcParse = locale.utcParse;\n return locale;\n}\n","import {timeYear, timeMonth, timeWeek, timeDay, timeHour, timeMinute, timeSecond, timeTicks, timeTickInterval} from \"d3-time\";\nimport {timeFormat} from \"d3-time-format\";\nimport continuous, {copy} from \"./continuous.js\";\nimport {initRange} from \"./init.js\";\nimport nice from \"./nice.js\";\n\nfunction date(t) {\n return new Date(t);\n}\n\nfunction number(t) {\n return t instanceof Date ? +t : +new Date(+t);\n}\n\nexport function calendar(ticks, tickInterval, year, month, week, day, hour, minute, second, format) {\n var scale = continuous(),\n invert = scale.invert,\n domain = scale.domain;\n\n var formatMillisecond = format(\".%L\"),\n formatSecond = format(\":%S\"),\n formatMinute = format(\"%I:%M\"),\n formatHour = format(\"%I %p\"),\n formatDay = format(\"%a %d\"),\n formatWeek = format(\"%b %d\"),\n formatMonth = format(\"%B\"),\n formatYear = format(\"%Y\");\n\n function tickFormat(date) {\n return (second(date) < date ? formatMillisecond\n : minute(date) < date ? formatSecond\n : hour(date) < date ? formatMinute\n : day(date) < date ? formatHour\n : month(date) < date ? (week(date) < date ? formatDay : formatWeek)\n : year(date) < date ? formatMonth\n : formatYear)(date);\n }\n\n scale.invert = function(y) {\n return new Date(invert(y));\n };\n\n scale.domain = function(_) {\n return arguments.length ? domain(Array.from(_, number)) : domain().map(date);\n };\n\n scale.ticks = function(interval) {\n var d = domain();\n return ticks(d[0], d[d.length - 1], interval == null ? 10 : interval);\n };\n\n scale.tickFormat = function(count, specifier) {\n return specifier == null ? tickFormat : format(specifier);\n };\n\n scale.nice = function(interval) {\n var d = domain();\n if (!interval || typeof interval.range !== \"function\") interval = tickInterval(d[0], d[d.length - 1], interval == null ? 10 : interval);\n return interval ? domain(nice(d, interval)) : scale;\n };\n\n scale.copy = function() {\n return copy(scale, calendar(ticks, tickInterval, year, month, week, day, hour, minute, second, format));\n };\n\n return scale;\n}\n\nexport default function time() {\n return initRange.apply(calendar(timeTicks, timeTickInterval, timeYear, timeMonth, timeWeek, timeDay, timeHour, timeMinute, timeSecond, timeFormat).domain([new Date(2000, 0, 1), new Date(2000, 0, 2)]), arguments);\n}\n","import {utcYear, utcMonth, utcWeek, utcDay, utcHour, utcMinute, utcSecond, utcTicks, utcTickInterval} from \"d3-time\";\nimport {utcFormat} from \"d3-time-format\";\nimport {calendar} from \"./time.js\";\nimport {initRange} from \"./init.js\";\n\nexport default function utcTime() {\n return initRange.apply(calendar(utcTicks, utcTickInterval, utcYear, utcMonth, utcWeek, utcDay, utcHour, utcMinute, utcSecond, utcFormat).domain([Date.UTC(2000, 0, 1), Date.UTC(2000, 0, 2)]), arguments);\n}\n","import {interpolate, interpolateRound} from \"d3-interpolate\";\nimport {identity} from \"./continuous.js\";\nimport {initInterpolator} from \"./init.js\";\nimport {linearish} from \"./linear.js\";\nimport {loggish} from \"./log.js\";\nimport {symlogish} from \"./symlog.js\";\nimport {powish} from \"./pow.js\";\n\nfunction transformer() {\n var x0 = 0,\n x1 = 1,\n t0,\n t1,\n k10,\n transform,\n interpolator = identity,\n clamp = false,\n unknown;\n\n function scale(x) {\n return x == null || isNaN(x = +x) ? unknown : interpolator(k10 === 0 ? 0.5 : (x = (transform(x) - t0) * k10, clamp ? Math.max(0, Math.min(1, x)) : x));\n }\n\n scale.domain = function(_) {\n return arguments.length ? ([x0, x1] = _, t0 = transform(x0 = +x0), t1 = transform(x1 = +x1), k10 = t0 === t1 ? 0 : 1 / (t1 - t0), scale) : [x0, x1];\n };\n\n scale.clamp = function(_) {\n return arguments.length ? (clamp = !!_, scale) : clamp;\n };\n\n scale.interpolator = function(_) {\n return arguments.length ? (interpolator = _, scale) : interpolator;\n };\n\n function range(interpolate) {\n return function(_) {\n var r0, r1;\n return arguments.length ? ([r0, r1] = _, interpolator = interpolate(r0, r1), scale) : [interpolator(0), interpolator(1)];\n };\n }\n\n scale.range = range(interpolate);\n\n scale.rangeRound = range(interpolateRound);\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : unknown;\n };\n\n return function(t) {\n transform = t, t0 = t(x0), t1 = t(x1), k10 = t0 === t1 ? 0 : 1 / (t1 - t0);\n return scale;\n };\n}\n\nexport function copy(source, target) {\n return target\n .domain(source.domain())\n .interpolator(source.interpolator())\n .clamp(source.clamp())\n .unknown(source.unknown());\n}\n\nexport default function sequential() {\n var scale = linearish(transformer()(identity));\n\n scale.copy = function() {\n return copy(scale, sequential());\n };\n\n return initInterpolator.apply(scale, arguments);\n}\n\nexport function sequentialLog() {\n var scale = loggish(transformer()).domain([1, 10]);\n\n scale.copy = function() {\n return copy(scale, sequentialLog()).base(scale.base());\n };\n\n return initInterpolator.apply(scale, arguments);\n}\n\nexport function sequentialSymlog() {\n var scale = symlogish(transformer());\n\n scale.copy = function() {\n return copy(scale, sequentialSymlog()).constant(scale.constant());\n };\n\n return initInterpolator.apply(scale, arguments);\n}\n\nexport function sequentialPow() {\n var scale = powish(transformer());\n\n scale.copy = function() {\n return copy(scale, sequentialPow()).exponent(scale.exponent());\n };\n\n return initInterpolator.apply(scale, arguments);\n}\n\nexport function sequentialSqrt() {\n return sequentialPow.apply(null, arguments).exponent(0.5);\n}\n","import {ascending, bisect, quantile} from \"d3-array\";\nimport {identity} from \"./continuous.js\";\nimport {initInterpolator} from \"./init.js\";\n\nexport default function sequentialQuantile() {\n var domain = [],\n interpolator = identity;\n\n function scale(x) {\n if (x != null && !isNaN(x = +x)) return interpolator((bisect(domain, x, 1) - 1) / (domain.length - 1));\n }\n\n scale.domain = function(_) {\n if (!arguments.length) return domain.slice();\n domain = [];\n for (let d of _) if (d != null && !isNaN(d = +d)) domain.push(d);\n domain.sort(ascending);\n return scale;\n };\n\n scale.interpolator = function(_) {\n return arguments.length ? (interpolator = _, scale) : interpolator;\n };\n\n scale.range = function() {\n return domain.map((d, i) => interpolator(i / (domain.length - 1)));\n };\n\n scale.quantiles = function(n) {\n return Array.from({length: n + 1}, (_, i) => quantile(domain, i / n));\n };\n\n scale.copy = function() {\n return sequentialQuantile(interpolator).domain(domain);\n };\n\n return initInterpolator.apply(scale, arguments);\n}\n","import {interpolate, interpolateRound, piecewise} from \"d3-interpolate\";\nimport {identity} from \"./continuous.js\";\nimport {initInterpolator} from \"./init.js\";\nimport {linearish} from \"./linear.js\";\nimport {loggish} from \"./log.js\";\nimport {copy} from \"./sequential.js\";\nimport {symlogish} from \"./symlog.js\";\nimport {powish} from \"./pow.js\";\n\nfunction transformer() {\n var x0 = 0,\n x1 = 0.5,\n x2 = 1,\n s = 1,\n t0,\n t1,\n t2,\n k10,\n k21,\n interpolator = identity,\n transform,\n clamp = false,\n unknown;\n\n function scale(x) {\n return isNaN(x = +x) ? unknown : (x = 0.5 + ((x = +transform(x)) - t1) * (s * x < s * t1 ? k10 : k21), interpolator(clamp ? Math.max(0, Math.min(1, x)) : x));\n }\n\n scale.domain = function(_) {\n return arguments.length ? ([x0, x1, x2] = _, t0 = transform(x0 = +x0), t1 = transform(x1 = +x1), t2 = transform(x2 = +x2), k10 = t0 === t1 ? 0 : 0.5 / (t1 - t0), k21 = t1 === t2 ? 0 : 0.5 / (t2 - t1), s = t1 < t0 ? -1 : 1, scale) : [x0, x1, x2];\n };\n\n scale.clamp = function(_) {\n return arguments.length ? (clamp = !!_, scale) : clamp;\n };\n\n scale.interpolator = function(_) {\n return arguments.length ? (interpolator = _, scale) : interpolator;\n };\n\n function range(interpolate) {\n return function(_) {\n var r0, r1, r2;\n return arguments.length ? ([r0, r1, r2] = _, interpolator = piecewise(interpolate, [r0, r1, r2]), scale) : [interpolator(0), interpolator(0.5), interpolator(1)];\n };\n }\n\n scale.range = range(interpolate);\n\n scale.rangeRound = range(interpolateRound);\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : unknown;\n };\n\n return function(t) {\n transform = t, t0 = t(x0), t1 = t(x1), t2 = t(x2), k10 = t0 === t1 ? 0 : 0.5 / (t1 - t0), k21 = t1 === t2 ? 0 : 0.5 / (t2 - t1), s = t1 < t0 ? -1 : 1;\n return scale;\n };\n}\n\nexport default function diverging() {\n var scale = linearish(transformer()(identity));\n\n scale.copy = function() {\n return copy(scale, diverging());\n };\n\n return initInterpolator.apply(scale, arguments);\n}\n\nexport function divergingLog() {\n var scale = loggish(transformer()).domain([0.1, 1, 10]);\n\n scale.copy = function() {\n return copy(scale, divergingLog()).base(scale.base());\n };\n\n return initInterpolator.apply(scale, arguments);\n}\n\nexport function divergingSymlog() {\n var scale = symlogish(transformer());\n\n scale.copy = function() {\n return copy(scale, divergingSymlog()).constant(scale.constant());\n };\n\n return initInterpolator.apply(scale, arguments);\n}\n\nexport function divergingPow() {\n var scale = powish(transformer());\n\n scale.copy = function() {\n return copy(scale, divergingPow()).exponent(scale.exponent());\n };\n\n return initInterpolator.apply(scale, arguments);\n}\n\nexport function divergingSqrt() {\n return divergingPow.apply(null, arguments).exponent(0.5);\n}\n","import {default as value} from \"./value.js\";\n\nexport default function piecewise(interpolate, values) {\n if (values === undefined) values = interpolate, interpolate = value;\n var i = 0, n = values.length - 1, v = values[0], I = new Array(n < 0 ? 0 : n);\n while (i < n) I[i] = interpolate(v, v = values[++i]);\n return function(t) {\n var i = Math.max(0, Math.min(n - 1, Math.floor(t *= n)));\n return I[i](t - i);\n };\n}\n","export function initRange(domain, range) {\n switch (arguments.length) {\n case 0: break;\n case 1: this.range(domain); break;\n default: this.range(range).domain(domain); break;\n }\n return this;\n}\n\nexport function initInterpolator(domain, interpolator) {\n switch (arguments.length) {\n case 0: break;\n case 1: {\n if (typeof domain === \"function\") this.interpolator(domain);\n else this.range(domain);\n break;\n }\n default: {\n this.domain(domain);\n if (typeof interpolator === \"function\") this.interpolator(interpolator);\n else this.range(interpolator);\n break;\n }\n }\n return this;\n}\n","import {ticks, tickIncrement} from \"d3-array\";\nimport continuous, {copy} from \"./continuous.js\";\nimport {initRange} from \"./init.js\";\nimport tickFormat from \"./tickFormat.js\";\n\nexport function linearish(scale) {\n var domain = scale.domain;\n\n scale.ticks = function(count) {\n var d = domain();\n return ticks(d[0], d[d.length - 1], count == null ? 10 : count);\n };\n\n scale.tickFormat = function(count, specifier) {\n var d = domain();\n return tickFormat(d[0], d[d.length - 1], count == null ? 10 : count, specifier);\n };\n\n scale.nice = function(count) {\n if (count == null) count = 10;\n\n var d = domain();\n var i0 = 0;\n var i1 = d.length - 1;\n var start = d[i0];\n var stop = d[i1];\n var prestep;\n var step;\n var maxIter = 10;\n\n if (stop < start) {\n step = start, start = stop, stop = step;\n step = i0, i0 = i1, i1 = step;\n }\n \n while (maxIter-- > 0) {\n step = tickIncrement(start, stop, count);\n if (step === prestep) {\n d[i0] = start\n d[i1] = stop\n return domain(d);\n } else if (step > 0) {\n start = Math.floor(start / step) * step;\n stop = Math.ceil(stop / step) * step;\n } else if (step < 0) {\n start = Math.ceil(start * step) / step;\n stop = Math.floor(stop * step) / step;\n } else {\n break;\n }\n prestep = step;\n }\n\n return scale;\n };\n\n return scale;\n}\n\nexport default function linear() {\n var scale = continuous();\n\n scale.copy = function() {\n return copy(scale, linear());\n };\n\n initRange.apply(scale, arguments);\n\n return linearish(scale);\n}\n","export default function number(x) {\n return +x;\n}\n","export class InternMap extends Map {\n constructor(entries, key = keyof) {\n super();\n Object.defineProperties(this, {_intern: {value: new Map()}, _key: {value: key}});\n if (entries != null) for (const [key, value] of entries) this.set(key, value);\n }\n get(key) {\n return super.get(intern_get(this, key));\n }\n has(key) {\n return super.has(intern_get(this, key));\n }\n set(key, value) {\n return super.set(intern_set(this, key), value);\n }\n delete(key) {\n return super.delete(intern_delete(this, key));\n }\n}\n\nexport class InternSet extends Set {\n constructor(values, key = keyof) {\n super();\n Object.defineProperties(this, {_intern: {value: new Map()}, _key: {value: key}});\n if (values != null) for (const value of values) this.add(value);\n }\n has(value) {\n return super.has(intern_get(this, value));\n }\n add(value) {\n return super.add(intern_set(this, value));\n }\n delete(value) {\n return super.delete(intern_delete(this, value));\n }\n}\n\nfunction intern_get({_intern, _key}, value) {\n const key = _key(value);\n return _intern.has(key) ? _intern.get(key) : value;\n}\n\nfunction intern_set({_intern, _key}, value) {\n const key = _key(value);\n if (_intern.has(key)) return _intern.get(key);\n _intern.set(key, value);\n return value;\n}\n\nfunction intern_delete({_intern, _key}, value) {\n const key = _key(value);\n if (_intern.has(key)) {\n value = _intern.get(key);\n _intern.delete(key);\n }\n return value;\n}\n\nfunction keyof(value) {\n return value !== null && typeof value === \"object\" ? value.valueOf() : value;\n}\n","import {InternMap} from \"d3-array\";\nimport {initRange} from \"./init.js\";\n\nexport const implicit = Symbol(\"implicit\");\n\nexport default function ordinal() {\n var index = new InternMap(),\n domain = [],\n range = [],\n unknown = implicit;\n\n function scale(d) {\n let i = index.get(d);\n if (i === undefined) {\n if (unknown !== implicit) return unknown;\n index.set(d, i = domain.push(d) - 1);\n }\n return range[i % range.length];\n }\n\n scale.domain = function(_) {\n if (!arguments.length) return domain.slice();\n domain = [], index = new InternMap();\n for (const value of _) {\n if (index.has(value)) continue;\n index.set(value, domain.push(value) - 1);\n }\n return scale;\n };\n\n scale.range = function(_) {\n return arguments.length ? (range = Array.from(_), scale) : range.slice();\n };\n\n scale.unknown = function(_) {\n return arguments.length ? (unknown = _, scale) : unknown;\n };\n\n scale.copy = function() {\n return ordinal(domain, range).unknown(unknown);\n };\n\n initRange.apply(scale, arguments);\n\n return scale;\n}\n","import {tickStep} from \"d3-array\";\nimport {format, formatPrefix, formatSpecifier, precisionFixed, precisionPrefix, precisionRound} from \"d3-format\";\n\nexport default function tickFormat(start, stop, count, specifier) {\n var step = tickStep(start, stop, count),\n precision;\n specifier = formatSpecifier(specifier == null ? \",f\" : specifier);\n switch (specifier.type) {\n case \"s\": {\n var value = Math.max(Math.abs(start), Math.abs(stop));\n if (specifier.precision == null && !isNaN(precision = precisionPrefix(step, value))) specifier.precision = precision;\n return formatPrefix(specifier, value);\n }\n case \"\":\n case \"e\":\n case \"g\":\n case \"p\":\n case \"r\": {\n if (specifier.precision == null && !isNaN(precision = precisionRound(step, Math.max(Math.abs(start), Math.abs(stop))))) specifier.precision = precision - (specifier.type === \"e\");\n break;\n }\n case \"f\":\n case \"%\": {\n if (specifier.precision == null && !isNaN(precision = precisionFixed(step))) specifier.precision = precision - (specifier.type === \"%\") * 2;\n break;\n }\n }\n return format(specifier);\n}\n","import exponent from \"./exponent.js\";\n\nexport default function(step, value) {\n return Math.max(0, Math.max(-8, Math.min(8, Math.floor(exponent(value) / 3))) * 3 - exponent(Math.abs(step)));\n}\n","import exponent from \"./exponent.js\";\n\nexport default function(step, max) {\n step = Math.abs(step), max = Math.abs(max) - step;\n return Math.max(0, exponent(max) - exponent(step)) + 1;\n}\n","import exponent from \"./exponent.js\";\n\nexport default function(step) {\n return Math.max(0, -exponent(Math.abs(step)));\n}\n"],"names":["DESCRIPTORS","isArray","$TypeError","TypeError","getOwnPropertyDescriptor","Object","SILENT_ON_NON_WRITABLE_LENGTH_SET","undefined","this","defineProperty","writable","length","error","module","exports","O","it","$","toObject","lengthOfArrayLike","setArrayLength","doesNotExceedSafeInteger","target","proto","arity","forced","fails","push","call","properErrorOnNonWritableLength","item","len","argCount","arguments","i","ascending","a","b","NaN","ascendingBisect","bisectRight","right","left","center","descending","bisector","f","compare1","compare2","delta","x","lo","hi","mid","d","zero","max","values","valueof","value","index","min","number","numbers","e10","Math","sqrt","e5","e2","ticks","start","stop","count","reverse","n","step","tickIncrement","isFinite","r0","round","r1","Array","power","floor","log","LN10","pow","tickStep","step0","abs","step1","constructor","factory","prototype","extend","parent","definition","create","key","Color","darker","brighter","reI","reN","reP","reHex","reRgbInteger","RegExp","reRgbPercent","reRgbaInteger","reRgbaPercent","reHslPercent","reHslaPercent","named","aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","cadetblue","chartreuse","chocolate","coral","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgreen","darkgrey","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkslategrey","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dimgrey","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","green","greenyellow","grey","honeydew","hotpink","indianred","indigo","ivory","khaki","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrodyellow","lightgray","lightgreen","lightgrey","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightslategrey","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","rebeccapurple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","slategrey","snow","springgreen","steelblue","tan","teal","thistle","tomato","turquoise","violet","wheat","white","whitesmoke","yellow","yellowgreen","color_formatHex","rgb","formatHex","color_formatRgb","formatRgb","color","format","m","l","trim","toLowerCase","exec","parseInt","rgbn","Rgb","rgba","hsla","hasOwnProperty","r","g","opacity","o","rgb_formatHex","hex","rgb_formatRgb","clampa","clampi","isNaN","toString","h","s","Hsl","hslConvert","clamph","clampt","hsl2rgb","m1","m2","copy","channels","assign","displayable","formatHex8","formatHsl","k","clamp","prefixExponent","p","formatDecimal","coefficient","exponent","join","slice","toFixed","toExponential","toPrecision","formatRounded","toUpperCase","formatPrefix","map","prefixes","locale","grouping","thousands","group","identity","Number","width","t","j","substring","currencyPrefix","currency","currencySuffix","decimal","numerals","replace","formatNumerals","String","percent","minus","nan","newFormat","specifier","fill","formatSpecifier","align","sign","symbol","comma","precision","type","formatTypes","prefix","test","suffix","formatType","maybeSuffix","c","valuePrefix","valueSuffix","valueNegative","out","i1","i0","formatTrim","charCodeAt","Infinity","padding","e","toLocaleString","formatDecimalParts","indexOf","re","match","Error","FormatSpecifier","basis","t1","v0","v1","v2","v3","t2","t3","linear","gamma","y","nogamma","exponential","rgbGamma","end","rgbSpline","spline","colors","reA","reB","source","am","bm","bs","bi","lastIndex","q","one","genericArray","nb","na","Date","setTime","constant","string","date","ArrayBuffer","isView","DataView","valueOf","object","band","bandwidth","scale","ordinal","unknown","domain","ordinalRange","range","paddingInner","paddingOuter","rescale","ceil","_","rangeRound","init","apply","pointish","point","unit","normalize","bimap","interpolate","d0","d1","polymap","bisect","transformer","transform","untransform","piecewise","output","input","invert","from","u","continuous","nice","interval","x0","x1","transformLog","transformExp","exp","transformLogn","transformExpn","pow10","reflect","loggish","logs","pows","base","E","log10","log2","logp","powp","v","z","tickFormat","transformSymlog","log1p","transformSymexp","expm1","symlogish","symlog","transformPow","transformSqrt","transformSquare","powish","square","radial","squared","unsquare","compareDefined","compare","array","sd","swap","quantile","Float64Array","value0","subarray","quantileSorted","thresholds","invertExtent","sort","quantiles","quantize","threshold","durationSecond","durationMinute","durationHour","durationDay","durationWeek","durationMonth","durationYear","t0","newInterval","floori","offseti","field","offset","previous","filter","every","millisecond","second","getMilliseconds","getUTCSeconds","minute","getSeconds","getMinutes","hour","getHours","day","setHours","setDate","getDate","getTimezoneOffset","weekday","getDay","sunday","monday","tuesday","wednesday","thursday","friday","saturday","month","setMonth","getMonth","getFullYear","year","setFullYear","utcMinute","setUTCSeconds","getUTCMinutes","utcHour","setUTCMinutes","getUTCHours","utcDay","setUTCHours","setUTCDate","getUTCDate","utcWeekday","getUTCDay","utcSunday","utcMonday","utcTuesday","utcWednesday","utcThursday","utcFriday","utcSaturday","utcMonth","setUTCMonth","getUTCMonth","getUTCFullYear","utcYear","setUTCFullYear","ticker","week","tickIntervals","tickInterval","utcTicks","utcTickInterval","timeTicks","timeTickInterval","localDate","H","M","S","L","utcDate","UTC","newDate","timeFormat","utcFormat","pads","numberRe","percentRe","requoteRe","pad","requote","formatRe","names","formatLookup","Map","name","parseWeekdayNumberSunday","w","parseWeekdayNumberMonday","parseWeekNumberSunday","U","parseWeekNumberISO","V","parseWeekNumberMonday","W","parseFullYear","parseYear","parseZone","Z","parseQuarter","parseMonthNumber","parseDayOfMonth","parseDayOfYear","parseHour24","parseMinutes","parseSeconds","parseMilliseconds","parseMicroseconds","parseLiteralPercent","parseUnixTimestamp","Q","parseUnixTimestampSeconds","formatDayOfMonth","formatHour24","formatHour12","formatDayOfYear","formatMilliseconds","formatMicroseconds","formatMonthNumber","formatMinutes","formatSeconds","formatWeekdayNumberMonday","formatWeekNumberSunday","dISO","formatWeekNumberISO","formatWeekdayNumberSunday","formatWeekNumberMonday","formatYear","formatYearISO","formatFullYear","formatFullYearISO","formatZone","formatUTCDayOfMonth","formatUTCHour24","formatUTCHour12","formatUTCDayOfYear","formatUTCMilliseconds","getUTCMilliseconds","formatUTCMicroseconds","formatUTCMonthNumber","formatUTCMinutes","formatUTCSeconds","formatUTCWeekdayNumberMonday","dow","formatUTCWeekNumberSunday","UTCdISO","formatUTCWeekNumberISO","formatUTCWeekdayNumberSunday","formatUTCWeekNumberMonday","formatUTCYear","formatUTCYearISO","formatUTCFullYear","formatUTCFullYearISO","formatUTCZone","formatLiteralPercent","formatUnixTimestamp","formatUnixTimestampSeconds","calendar","formatMillisecond","formatSecond","formatMinute","formatHour","formatDay","formatWeek","formatMonth","time","utcTime","locale_dateTime","dateTime","locale_date","locale_time","locale_periods","periods","locale_weekdays","days","locale_shortWeekdays","shortDays","locale_months","months","locale_shortMonths","shortMonths","periodRe","periodLookup","weekdayRe","weekdayLookup","shortWeekdayRe","shortWeekdayLookup","monthRe","monthLookup","shortMonthRe","shortMonthLookup","formats","utcFormats","parses","get","parseSpecifier","charAt","newParse","parse","X","utcParse","formatLocale","k10","interpolator","sequential","sequentialLog","sequentialSymlog","sequentialPow","sequentialSqrt","sequentialQuantile","k21","x2","r2","I","diverging","divergingLog","divergingSymlog","divergingPow","divergingSqrt","initRange","initInterpolator","linearish","prestep","maxIter","InternMap","entries","keyof","super","defineProperties","_intern","_key","set","intern_get","has","intern_set","delete","intern_delete","Set","implicit","Symbol","precisionPrefix","precisionRound","precisionFixed"],"sourceRoot":""}