12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196 |
- // https://d3js.org/d3-scale/ v4.0.2 Copyright 2010-2021 Mike Bostock
- (function (global, factory) {
- typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('d3-array'), require('d3-interpolate'), require('d3-format'), require('d3-time'), require('d3-time-format')) :
- typeof define === 'function' && define.amd ? define(['exports', 'd3-array', 'd3-interpolate', 'd3-format', 'd3-time', 'd3-time-format'], factory) :
- (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.d3 = global.d3 || {}, global.d3, global.d3, global.d3, global.d3, global.d3));
- })(this, (function (exports, d3Array, d3Interpolate, d3Format, d3Time, d3TimeFormat) { 'use strict';
-
- function initRange(domain, range) {
- switch (arguments.length) {
- case 0: break;
- case 1: this.range(domain); break;
- default: this.range(range).domain(domain); break;
- }
- return this;
- }
-
- function initInterpolator(domain, interpolator) {
- switch (arguments.length) {
- case 0: break;
- case 1: {
- if (typeof domain === "function") this.interpolator(domain);
- else this.range(domain);
- break;
- }
- default: {
- this.domain(domain);
- if (typeof interpolator === "function") this.interpolator(interpolator);
- else this.range(interpolator);
- break;
- }
- }
- return this;
- }
-
- const implicit = Symbol("implicit");
-
- function ordinal() {
- var index = new d3Array.InternMap(),
- domain = [],
- range = [],
- unknown = implicit;
-
- function scale(d) {
- let i = index.get(d);
- if (i === undefined) {
- if (unknown !== implicit) return unknown;
- index.set(d, i = domain.push(d) - 1);
- }
- return range[i % range.length];
- }
-
- scale.domain = function(_) {
- if (!arguments.length) return domain.slice();
- domain = [], index = new d3Array.InternMap();
- for (const value of _) {
- if (index.has(value)) continue;
- index.set(value, domain.push(value) - 1);
- }
- return scale;
- };
-
- scale.range = function(_) {
- return arguments.length ? (range = Array.from(_), scale) : range.slice();
- };
-
- scale.unknown = function(_) {
- return arguments.length ? (unknown = _, scale) : unknown;
- };
-
- scale.copy = function() {
- return ordinal(domain, range).unknown(unknown);
- };
-
- initRange.apply(scale, arguments);
-
- return scale;
- }
-
- function band() {
- var scale = ordinal().unknown(undefined),
- domain = scale.domain,
- ordinalRange = scale.range,
- r0 = 0,
- r1 = 1,
- step,
- bandwidth,
- round = false,
- paddingInner = 0,
- paddingOuter = 0,
- align = 0.5;
-
- delete scale.unknown;
-
- function rescale() {
- var n = domain().length,
- reverse = r1 < r0,
- start = reverse ? r1 : r0,
- stop = reverse ? r0 : r1;
- step = (stop - start) / Math.max(1, n - paddingInner + paddingOuter * 2);
- if (round) step = Math.floor(step);
- start += (stop - start - step * (n - paddingInner)) * align;
- bandwidth = step * (1 - paddingInner);
- if (round) start = Math.round(start), bandwidth = Math.round(bandwidth);
- var values = d3Array.range(n).map(function(i) { return start + step * i; });
- return ordinalRange(reverse ? values.reverse() : values);
- }
-
- scale.domain = function(_) {
- return arguments.length ? (domain(_), rescale()) : domain();
- };
-
- scale.range = function(_) {
- return arguments.length ? ([r0, r1] = _, r0 = +r0, r1 = +r1, rescale()) : [r0, r1];
- };
-
- scale.rangeRound = function(_) {
- return [r0, r1] = _, r0 = +r0, r1 = +r1, round = true, rescale();
- };
-
- scale.bandwidth = function() {
- return bandwidth;
- };
-
- scale.step = function() {
- return step;
- };
-
- scale.round = function(_) {
- return arguments.length ? (round = !!_, rescale()) : round;
- };
-
- scale.padding = function(_) {
- return arguments.length ? (paddingInner = Math.min(1, paddingOuter = +_), rescale()) : paddingInner;
- };
-
- scale.paddingInner = function(_) {
- return arguments.length ? (paddingInner = Math.min(1, _), rescale()) : paddingInner;
- };
-
- scale.paddingOuter = function(_) {
- return arguments.length ? (paddingOuter = +_, rescale()) : paddingOuter;
- };
-
- scale.align = function(_) {
- return arguments.length ? (align = Math.max(0, Math.min(1, _)), rescale()) : align;
- };
-
- scale.copy = function() {
- return band(domain(), [r0, r1])
- .round(round)
- .paddingInner(paddingInner)
- .paddingOuter(paddingOuter)
- .align(align);
- };
-
- return initRange.apply(rescale(), arguments);
- }
-
- function pointish(scale) {
- var copy = scale.copy;
-
- scale.padding = scale.paddingOuter;
- delete scale.paddingInner;
- delete scale.paddingOuter;
-
- scale.copy = function() {
- return pointish(copy());
- };
-
- return scale;
- }
-
- function point() {
- return pointish(band.apply(null, arguments).paddingInner(1));
- }
-
- function constants(x) {
- return function() {
- return x;
- };
- }
-
- function number$1(x) {
- return +x;
- }
-
- var unit = [0, 1];
-
- function identity$1(x) {
- return x;
- }
-
- function normalize(a, b) {
- return (b -= (a = +a))
- ? function(x) { return (x - a) / b; }
- : constants(isNaN(b) ? NaN : 0.5);
- }
-
- function clamper(a, b) {
- var t;
- if (a > b) t = a, a = b, b = t;
- return function(x) { return Math.max(a, Math.min(b, x)); };
- }
-
- // normalize(a, b)(x) takes a domain value x in [a,b] and returns the corresponding parameter t in [0,1].
- // interpolate(a, b)(t) takes a parameter t in [0,1] and returns the corresponding range value x in [a,b].
- function bimap(domain, range, interpolate) {
- var d0 = domain[0], d1 = domain[1], r0 = range[0], r1 = range[1];
- if (d1 < d0) d0 = normalize(d1, d0), r0 = interpolate(r1, r0);
- else d0 = normalize(d0, d1), r0 = interpolate(r0, r1);
- return function(x) { return r0(d0(x)); };
- }
-
- function polymap(domain, range, interpolate) {
- var j = Math.min(domain.length, range.length) - 1,
- d = new Array(j),
- r = new Array(j),
- i = -1;
-
- // Reverse descending domains.
- if (domain[j] < domain[0]) {
- domain = domain.slice().reverse();
- range = range.slice().reverse();
- }
-
- while (++i < j) {
- d[i] = normalize(domain[i], domain[i + 1]);
- r[i] = interpolate(range[i], range[i + 1]);
- }
-
- return function(x) {
- var i = d3Array.bisect(domain, x, 1, j) - 1;
- return r[i](d[i](x));
- };
- }
-
- function copy$1(source, target) {
- return target
- .domain(source.domain())
- .range(source.range())
- .interpolate(source.interpolate())
- .clamp(source.clamp())
- .unknown(source.unknown());
- }
-
- function transformer$2() {
- var domain = unit,
- range = unit,
- interpolate = d3Interpolate.interpolate,
- transform,
- untransform,
- unknown,
- clamp = identity$1,
- piecewise,
- output,
- input;
-
- function rescale() {
- var n = Math.min(domain.length, range.length);
- if (clamp !== identity$1) clamp = clamper(domain[0], domain[n - 1]);
- piecewise = n > 2 ? polymap : bimap;
- output = input = null;
- return scale;
- }
-
- function scale(x) {
- return x == null || isNaN(x = +x) ? unknown : (output || (output = piecewise(domain.map(transform), range, interpolate)))(transform(clamp(x)));
- }
-
- scale.invert = function(y) {
- return clamp(untransform((input || (input = piecewise(range, domain.map(transform), d3Interpolate.interpolateNumber)))(y)));
- };
-
- scale.domain = function(_) {
- return arguments.length ? (domain = Array.from(_, number$1), rescale()) : domain.slice();
- };
-
- scale.range = function(_) {
- return arguments.length ? (range = Array.from(_), rescale()) : range.slice();
- };
-
- scale.rangeRound = function(_) {
- return range = Array.from(_), interpolate = d3Interpolate.interpolateRound, rescale();
- };
-
- scale.clamp = function(_) {
- return arguments.length ? (clamp = _ ? true : identity$1, rescale()) : clamp !== identity$1;
- };
-
- scale.interpolate = function(_) {
- return arguments.length ? (interpolate = _, rescale()) : interpolate;
- };
-
- scale.unknown = function(_) {
- return arguments.length ? (unknown = _, scale) : unknown;
- };
-
- return function(t, u) {
- transform = t, untransform = u;
- return rescale();
- };
- }
-
- function continuous() {
- return transformer$2()(identity$1, identity$1);
- }
-
- function tickFormat(start, stop, count, specifier) {
- var step = d3Array.tickStep(start, stop, count),
- precision;
- specifier = d3Format.formatSpecifier(specifier == null ? ",f" : specifier);
- switch (specifier.type) {
- case "s": {
- var value = Math.max(Math.abs(start), Math.abs(stop));
- if (specifier.precision == null && !isNaN(precision = d3Format.precisionPrefix(step, value))) specifier.precision = precision;
- return d3Format.formatPrefix(specifier, value);
- }
- case "":
- case "e":
- case "g":
- case "p":
- case "r": {
- if (specifier.precision == null && !isNaN(precision = d3Format.precisionRound(step, Math.max(Math.abs(start), Math.abs(stop))))) specifier.precision = precision - (specifier.type === "e");
- break;
- }
- case "f":
- case "%": {
- if (specifier.precision == null && !isNaN(precision = d3Format.precisionFixed(step))) specifier.precision = precision - (specifier.type === "%") * 2;
- break;
- }
- }
- return d3Format.format(specifier);
- }
-
- function linearish(scale) {
- var domain = scale.domain;
-
- scale.ticks = function(count) {
- var d = domain();
- return d3Array.ticks(d[0], d[d.length - 1], count == null ? 10 : count);
- };
-
- scale.tickFormat = function(count, specifier) {
- var d = domain();
- return tickFormat(d[0], d[d.length - 1], count == null ? 10 : count, specifier);
- };
-
- scale.nice = function(count) {
- if (count == null) count = 10;
-
- var d = domain();
- var i0 = 0;
- var i1 = d.length - 1;
- var start = d[i0];
- var stop = d[i1];
- var prestep;
- var step;
- var maxIter = 10;
-
- if (stop < start) {
- step = start, start = stop, stop = step;
- step = i0, i0 = i1, i1 = step;
- }
-
- while (maxIter-- > 0) {
- step = d3Array.tickIncrement(start, stop, count);
- if (step === prestep) {
- d[i0] = start;
- d[i1] = stop;
- return domain(d);
- } else if (step > 0) {
- start = Math.floor(start / step) * step;
- stop = Math.ceil(stop / step) * step;
- } else if (step < 0) {
- start = Math.ceil(start * step) / step;
- stop = Math.floor(stop * step) / step;
- } else {
- break;
- }
- prestep = step;
- }
-
- return scale;
- };
-
- return scale;
- }
-
- function linear() {
- var scale = continuous();
-
- scale.copy = function() {
- return copy$1(scale, linear());
- };
-
- initRange.apply(scale, arguments);
-
- return linearish(scale);
- }
-
- function identity(domain) {
- var unknown;
-
- function scale(x) {
- return x == null || isNaN(x = +x) ? unknown : x;
- }
-
- scale.invert = scale;
-
- scale.domain = scale.range = function(_) {
- return arguments.length ? (domain = Array.from(_, number$1), scale) : domain.slice();
- };
-
- scale.unknown = function(_) {
- return arguments.length ? (unknown = _, scale) : unknown;
- };
-
- scale.copy = function() {
- return identity(domain).unknown(unknown);
- };
-
- domain = arguments.length ? Array.from(domain, number$1) : [0, 1];
-
- return linearish(scale);
- }
-
- function nice(domain, interval) {
- domain = domain.slice();
-
- var i0 = 0,
- i1 = domain.length - 1,
- x0 = domain[i0],
- x1 = domain[i1],
- t;
-
- if (x1 < x0) {
- t = i0, i0 = i1, i1 = t;
- t = x0, x0 = x1, x1 = t;
- }
-
- domain[i0] = interval.floor(x0);
- domain[i1] = interval.ceil(x1);
- return domain;
- }
-
- function transformLog(x) {
- return Math.log(x);
- }
-
- function transformExp(x) {
- return Math.exp(x);
- }
-
- function transformLogn(x) {
- return -Math.log(-x);
- }
-
- function transformExpn(x) {
- return -Math.exp(-x);
- }
-
- function pow10(x) {
- return isFinite(x) ? +("1e" + x) : x < 0 ? 0 : x;
- }
-
- function powp(base) {
- return base === 10 ? pow10
- : base === Math.E ? Math.exp
- : x => Math.pow(base, x);
- }
-
- function logp(base) {
- return base === Math.E ? Math.log
- : base === 10 && Math.log10
- || base === 2 && Math.log2
- || (base = Math.log(base), x => Math.log(x) / base);
- }
-
- function reflect(f) {
- return (x, k) => -f(-x, k);
- }
-
- function loggish(transform) {
- const scale = transform(transformLog, transformExp);
- const domain = scale.domain;
- let base = 10;
- let logs;
- let pows;
-
- function rescale() {
- logs = logp(base), pows = powp(base);
- if (domain()[0] < 0) {
- logs = reflect(logs), pows = reflect(pows);
- transform(transformLogn, transformExpn);
- } else {
- transform(transformLog, transformExp);
- }
- return scale;
- }
-
- scale.base = function(_) {
- return arguments.length ? (base = +_, rescale()) : base;
- };
-
- scale.domain = function(_) {
- return arguments.length ? (domain(_), rescale()) : domain();
- };
-
- scale.ticks = count => {
- const d = domain();
- let u = d[0];
- let v = d[d.length - 1];
- const r = v < u;
-
- if (r) ([u, v] = [v, u]);
-
- let i = logs(u);
- let j = logs(v);
- let k;
- let t;
- const n = count == null ? 10 : +count;
- let z = [];
-
- if (!(base % 1) && j - i < n) {
- i = Math.floor(i), j = Math.ceil(j);
- if (u > 0) for (; i <= j; ++i) {
- for (k = 1; k < base; ++k) {
- t = i < 0 ? k / pows(-i) : k * pows(i);
- if (t < u) continue;
- if (t > v) break;
- z.push(t);
- }
- } else for (; i <= j; ++i) {
- for (k = base - 1; k >= 1; --k) {
- t = i > 0 ? k / pows(-i) : k * pows(i);
- if (t < u) continue;
- if (t > v) break;
- z.push(t);
- }
- }
- if (z.length * 2 < n) z = d3Array.ticks(u, v, n);
- } else {
- z = d3Array.ticks(i, j, Math.min(j - i, n)).map(pows);
- }
- return r ? z.reverse() : z;
- };
-
- scale.tickFormat = (count, specifier) => {
- if (count == null) count = 10;
- if (specifier == null) specifier = base === 10 ? "s" : ",";
- if (typeof specifier !== "function") {
- if (!(base % 1) && (specifier = d3Format.formatSpecifier(specifier)).precision == null) specifier.trim = true;
- specifier = d3Format.format(specifier);
- }
- if (count === Infinity) return specifier;
- const k = Math.max(1, base * count / scale.ticks().length); // TODO fast estimate?
- return d => {
- let i = d / pows(Math.round(logs(d)));
- if (i * base < base - 0.5) i *= base;
- return i <= k ? specifier(d) : "";
- };
- };
-
- scale.nice = () => {
- return domain(nice(domain(), {
- floor: x => pows(Math.floor(logs(x))),
- ceil: x => pows(Math.ceil(logs(x)))
- }));
- };
-
- return scale;
- }
-
- function log() {
- const scale = loggish(transformer$2()).domain([1, 10]);
- scale.copy = () => copy$1(scale, log()).base(scale.base());
- initRange.apply(scale, arguments);
- return scale;
- }
-
- function transformSymlog(c) {
- return function(x) {
- return Math.sign(x) * Math.log1p(Math.abs(x / c));
- };
- }
-
- function transformSymexp(c) {
- return function(x) {
- return Math.sign(x) * Math.expm1(Math.abs(x)) * c;
- };
- }
-
- function symlogish(transform) {
- var c = 1, scale = transform(transformSymlog(c), transformSymexp(c));
-
- scale.constant = function(_) {
- return arguments.length ? transform(transformSymlog(c = +_), transformSymexp(c)) : c;
- };
-
- return linearish(scale);
- }
-
- function symlog() {
- var scale = symlogish(transformer$2());
-
- scale.copy = function() {
- return copy$1(scale, symlog()).constant(scale.constant());
- };
-
- return initRange.apply(scale, arguments);
- }
-
- function transformPow(exponent) {
- return function(x) {
- return x < 0 ? -Math.pow(-x, exponent) : Math.pow(x, exponent);
- };
- }
-
- function transformSqrt(x) {
- return x < 0 ? -Math.sqrt(-x) : Math.sqrt(x);
- }
-
- function transformSquare(x) {
- return x < 0 ? -x * x : x * x;
- }
-
- function powish(transform) {
- var scale = transform(identity$1, identity$1),
- exponent = 1;
-
- function rescale() {
- return exponent === 1 ? transform(identity$1, identity$1)
- : exponent === 0.5 ? transform(transformSqrt, transformSquare)
- : transform(transformPow(exponent), transformPow(1 / exponent));
- }
-
- scale.exponent = function(_) {
- return arguments.length ? (exponent = +_, rescale()) : exponent;
- };
-
- return linearish(scale);
- }
-
- function pow() {
- var scale = powish(transformer$2());
-
- scale.copy = function() {
- return copy$1(scale, pow()).exponent(scale.exponent());
- };
-
- initRange.apply(scale, arguments);
-
- return scale;
- }
-
- function sqrt() {
- return pow.apply(null, arguments).exponent(0.5);
- }
-
- function square(x) {
- return Math.sign(x) * x * x;
- }
-
- function unsquare(x) {
- return Math.sign(x) * Math.sqrt(Math.abs(x));
- }
-
- function radial() {
- var squared = continuous(),
- range = [0, 1],
- round = false,
- unknown;
-
- function scale(x) {
- var y = unsquare(squared(x));
- return isNaN(y) ? unknown : round ? Math.round(y) : y;
- }
-
- scale.invert = function(y) {
- return squared.invert(square(y));
- };
-
- scale.domain = function(_) {
- return arguments.length ? (squared.domain(_), scale) : squared.domain();
- };
-
- scale.range = function(_) {
- return arguments.length ? (squared.range((range = Array.from(_, number$1)).map(square)), scale) : range.slice();
- };
-
- scale.rangeRound = function(_) {
- return scale.range(_).round(true);
- };
-
- scale.round = function(_) {
- return arguments.length ? (round = !!_, scale) : round;
- };
-
- scale.clamp = function(_) {
- return arguments.length ? (squared.clamp(_), scale) : squared.clamp();
- };
-
- scale.unknown = function(_) {
- return arguments.length ? (unknown = _, scale) : unknown;
- };
-
- scale.copy = function() {
- return radial(squared.domain(), range)
- .round(round)
- .clamp(squared.clamp())
- .unknown(unknown);
- };
-
- initRange.apply(scale, arguments);
-
- return linearish(scale);
- }
-
- function quantile() {
- var domain = [],
- range = [],
- thresholds = [],
- unknown;
-
- function rescale() {
- var i = 0, n = Math.max(1, range.length);
- thresholds = new Array(n - 1);
- while (++i < n) thresholds[i - 1] = d3Array.quantileSorted(domain, i / n);
- return scale;
- }
-
- function scale(x) {
- return x == null || isNaN(x = +x) ? unknown : range[d3Array.bisect(thresholds, x)];
- }
-
- scale.invertExtent = function(y) {
- var i = range.indexOf(y);
- return i < 0 ? [NaN, NaN] : [
- i > 0 ? thresholds[i - 1] : domain[0],
- i < thresholds.length ? thresholds[i] : domain[domain.length - 1]
- ];
- };
-
- scale.domain = function(_) {
- if (!arguments.length) return domain.slice();
- domain = [];
- for (let d of _) if (d != null && !isNaN(d = +d)) domain.push(d);
- domain.sort(d3Array.ascending);
- return rescale();
- };
-
- scale.range = function(_) {
- return arguments.length ? (range = Array.from(_), rescale()) : range.slice();
- };
-
- scale.unknown = function(_) {
- return arguments.length ? (unknown = _, scale) : unknown;
- };
-
- scale.quantiles = function() {
- return thresholds.slice();
- };
-
- scale.copy = function() {
- return quantile()
- .domain(domain)
- .range(range)
- .unknown(unknown);
- };
-
- return initRange.apply(scale, arguments);
- }
-
- function quantize() {
- var x0 = 0,
- x1 = 1,
- n = 1,
- domain = [0.5],
- range = [0, 1],
- unknown;
-
- function scale(x) {
- return x != null && x <= x ? range[d3Array.bisect(domain, x, 0, n)] : unknown;
- }
-
- function rescale() {
- var i = -1;
- domain = new Array(n);
- while (++i < n) domain[i] = ((i + 1) * x1 - (i - n) * x0) / (n + 1);
- return scale;
- }
-
- scale.domain = function(_) {
- return arguments.length ? ([x0, x1] = _, x0 = +x0, x1 = +x1, rescale()) : [x0, x1];
- };
-
- scale.range = function(_) {
- return arguments.length ? (n = (range = Array.from(_)).length - 1, rescale()) : range.slice();
- };
-
- scale.invertExtent = function(y) {
- var i = range.indexOf(y);
- return i < 0 ? [NaN, NaN]
- : i < 1 ? [x0, domain[0]]
- : i >= n ? [domain[n - 1], x1]
- : [domain[i - 1], domain[i]];
- };
-
- scale.unknown = function(_) {
- return arguments.length ? (unknown = _, scale) : scale;
- };
-
- scale.thresholds = function() {
- return domain.slice();
- };
-
- scale.copy = function() {
- return quantize()
- .domain([x0, x1])
- .range(range)
- .unknown(unknown);
- };
-
- return initRange.apply(linearish(scale), arguments);
- }
-
- function threshold() {
- var domain = [0.5],
- range = [0, 1],
- unknown,
- n = 1;
-
- function scale(x) {
- return x != null && x <= x ? range[d3Array.bisect(domain, x, 0, n)] : unknown;
- }
-
- scale.domain = function(_) {
- return arguments.length ? (domain = Array.from(_), n = Math.min(domain.length, range.length - 1), scale) : domain.slice();
- };
-
- scale.range = function(_) {
- return arguments.length ? (range = Array.from(_), n = Math.min(domain.length, range.length - 1), scale) : range.slice();
- };
-
- scale.invertExtent = function(y) {
- var i = range.indexOf(y);
- return [domain[i - 1], domain[i]];
- };
-
- scale.unknown = function(_) {
- return arguments.length ? (unknown = _, scale) : unknown;
- };
-
- scale.copy = function() {
- return threshold()
- .domain(domain)
- .range(range)
- .unknown(unknown);
- };
-
- return initRange.apply(scale, arguments);
- }
-
- function date(t) {
- return new Date(t);
- }
-
- function number(t) {
- return t instanceof Date ? +t : +new Date(+t);
- }
-
- function calendar(ticks, tickInterval, year, month, week, day, hour, minute, second, format) {
- var scale = continuous(),
- invert = scale.invert,
- domain = scale.domain;
-
- var formatMillisecond = format(".%L"),
- formatSecond = format(":%S"),
- formatMinute = format("%I:%M"),
- formatHour = format("%I %p"),
- formatDay = format("%a %d"),
- formatWeek = format("%b %d"),
- formatMonth = format("%B"),
- formatYear = format("%Y");
-
- function tickFormat(date) {
- return (second(date) < date ? formatMillisecond
- : minute(date) < date ? formatSecond
- : hour(date) < date ? formatMinute
- : day(date) < date ? formatHour
- : month(date) < date ? (week(date) < date ? formatDay : formatWeek)
- : year(date) < date ? formatMonth
- : formatYear)(date);
- }
-
- scale.invert = function(y) {
- return new Date(invert(y));
- };
-
- scale.domain = function(_) {
- return arguments.length ? domain(Array.from(_, number)) : domain().map(date);
- };
-
- scale.ticks = function(interval) {
- var d = domain();
- return ticks(d[0], d[d.length - 1], interval == null ? 10 : interval);
- };
-
- scale.tickFormat = function(count, specifier) {
- return specifier == null ? tickFormat : format(specifier);
- };
-
- scale.nice = function(interval) {
- var d = domain();
- if (!interval || typeof interval.range !== "function") interval = tickInterval(d[0], d[d.length - 1], interval == null ? 10 : interval);
- return interval ? domain(nice(d, interval)) : scale;
- };
-
- scale.copy = function() {
- return copy$1(scale, calendar(ticks, tickInterval, year, month, week, day, hour, minute, second, format));
- };
-
- return scale;
- }
-
- function time() {
- return initRange.apply(calendar(d3Time.timeTicks, d3Time.timeTickInterval, d3Time.timeYear, d3Time.timeMonth, d3Time.timeWeek, d3Time.timeDay, d3Time.timeHour, d3Time.timeMinute, d3Time.timeSecond, d3TimeFormat.timeFormat).domain([new Date(2000, 0, 1), new Date(2000, 0, 2)]), arguments);
- }
-
- function utcTime() {
- return initRange.apply(calendar(d3Time.utcTicks, d3Time.utcTickInterval, d3Time.utcYear, d3Time.utcMonth, d3Time.utcWeek, d3Time.utcDay, d3Time.utcHour, d3Time.utcMinute, d3Time.utcSecond, d3TimeFormat.utcFormat).domain([Date.UTC(2000, 0, 1), Date.UTC(2000, 0, 2)]), arguments);
- }
-
- function transformer$1() {
- var x0 = 0,
- x1 = 1,
- t0,
- t1,
- k10,
- transform,
- interpolator = identity$1,
- clamp = false,
- unknown;
-
- function scale(x) {
- 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));
- }
-
- scale.domain = function(_) {
- return arguments.length ? ([x0, x1] = _, t0 = transform(x0 = +x0), t1 = transform(x1 = +x1), k10 = t0 === t1 ? 0 : 1 / (t1 - t0), scale) : [x0, x1];
- };
-
- scale.clamp = function(_) {
- return arguments.length ? (clamp = !!_, scale) : clamp;
- };
-
- scale.interpolator = function(_) {
- return arguments.length ? (interpolator = _, scale) : interpolator;
- };
-
- function range(interpolate) {
- return function(_) {
- var r0, r1;
- return arguments.length ? ([r0, r1] = _, interpolator = interpolate(r0, r1), scale) : [interpolator(0), interpolator(1)];
- };
- }
-
- scale.range = range(d3Interpolate.interpolate);
-
- scale.rangeRound = range(d3Interpolate.interpolateRound);
-
- scale.unknown = function(_) {
- return arguments.length ? (unknown = _, scale) : unknown;
- };
-
- return function(t) {
- transform = t, t0 = t(x0), t1 = t(x1), k10 = t0 === t1 ? 0 : 1 / (t1 - t0);
- return scale;
- };
- }
-
- function copy(source, target) {
- return target
- .domain(source.domain())
- .interpolator(source.interpolator())
- .clamp(source.clamp())
- .unknown(source.unknown());
- }
-
- function sequential() {
- var scale = linearish(transformer$1()(identity$1));
-
- scale.copy = function() {
- return copy(scale, sequential());
- };
-
- return initInterpolator.apply(scale, arguments);
- }
-
- function sequentialLog() {
- var scale = loggish(transformer$1()).domain([1, 10]);
-
- scale.copy = function() {
- return copy(scale, sequentialLog()).base(scale.base());
- };
-
- return initInterpolator.apply(scale, arguments);
- }
-
- function sequentialSymlog() {
- var scale = symlogish(transformer$1());
-
- scale.copy = function() {
- return copy(scale, sequentialSymlog()).constant(scale.constant());
- };
-
- return initInterpolator.apply(scale, arguments);
- }
-
- function sequentialPow() {
- var scale = powish(transformer$1());
-
- scale.copy = function() {
- return copy(scale, sequentialPow()).exponent(scale.exponent());
- };
-
- return initInterpolator.apply(scale, arguments);
- }
-
- function sequentialSqrt() {
- return sequentialPow.apply(null, arguments).exponent(0.5);
- }
-
- function sequentialQuantile() {
- var domain = [],
- interpolator = identity$1;
-
- function scale(x) {
- if (x != null && !isNaN(x = +x)) return interpolator((d3Array.bisect(domain, x, 1) - 1) / (domain.length - 1));
- }
-
- scale.domain = function(_) {
- if (!arguments.length) return domain.slice();
- domain = [];
- for (let d of _) if (d != null && !isNaN(d = +d)) domain.push(d);
- domain.sort(d3Array.ascending);
- return scale;
- };
-
- scale.interpolator = function(_) {
- return arguments.length ? (interpolator = _, scale) : interpolator;
- };
-
- scale.range = function() {
- return domain.map((d, i) => interpolator(i / (domain.length - 1)));
- };
-
- scale.quantiles = function(n) {
- return Array.from({length: n + 1}, (_, i) => d3Array.quantile(domain, i / n));
- };
-
- scale.copy = function() {
- return sequentialQuantile(interpolator).domain(domain);
- };
-
- return initInterpolator.apply(scale, arguments);
- }
-
- function transformer() {
- var x0 = 0,
- x1 = 0.5,
- x2 = 1,
- s = 1,
- t0,
- t1,
- t2,
- k10,
- k21,
- interpolator = identity$1,
- transform,
- clamp = false,
- unknown;
-
- function scale(x) {
- 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));
- }
-
- scale.domain = function(_) {
- 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];
- };
-
- scale.clamp = function(_) {
- return arguments.length ? (clamp = !!_, scale) : clamp;
- };
-
- scale.interpolator = function(_) {
- return arguments.length ? (interpolator = _, scale) : interpolator;
- };
-
- function range(interpolate) {
- return function(_) {
- var r0, r1, r2;
- return arguments.length ? ([r0, r1, r2] = _, interpolator = d3Interpolate.piecewise(interpolate, [r0, r1, r2]), scale) : [interpolator(0), interpolator(0.5), interpolator(1)];
- };
- }
-
- scale.range = range(d3Interpolate.interpolate);
-
- scale.rangeRound = range(d3Interpolate.interpolateRound);
-
- scale.unknown = function(_) {
- return arguments.length ? (unknown = _, scale) : unknown;
- };
-
- return function(t) {
- 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;
- return scale;
- };
- }
-
- function diverging() {
- var scale = linearish(transformer()(identity$1));
-
- scale.copy = function() {
- return copy(scale, diverging());
- };
-
- return initInterpolator.apply(scale, arguments);
- }
-
- function divergingLog() {
- var scale = loggish(transformer()).domain([0.1, 1, 10]);
-
- scale.copy = function() {
- return copy(scale, divergingLog()).base(scale.base());
- };
-
- return initInterpolator.apply(scale, arguments);
- }
-
- function divergingSymlog() {
- var scale = symlogish(transformer());
-
- scale.copy = function() {
- return copy(scale, divergingSymlog()).constant(scale.constant());
- };
-
- return initInterpolator.apply(scale, arguments);
- }
-
- function divergingPow() {
- var scale = powish(transformer());
-
- scale.copy = function() {
- return copy(scale, divergingPow()).exponent(scale.exponent());
- };
-
- return initInterpolator.apply(scale, arguments);
- }
-
- function divergingSqrt() {
- return divergingPow.apply(null, arguments).exponent(0.5);
- }
-
- exports.scaleBand = band;
- exports.scaleDiverging = diverging;
- exports.scaleDivergingLog = divergingLog;
- exports.scaleDivergingPow = divergingPow;
- exports.scaleDivergingSqrt = divergingSqrt;
- exports.scaleDivergingSymlog = divergingSymlog;
- exports.scaleIdentity = identity;
- exports.scaleImplicit = implicit;
- exports.scaleLinear = linear;
- exports.scaleLog = log;
- exports.scaleOrdinal = ordinal;
- exports.scalePoint = point;
- exports.scalePow = pow;
- exports.scaleQuantile = quantile;
- exports.scaleQuantize = quantize;
- exports.scaleRadial = radial;
- exports.scaleSequential = sequential;
- exports.scaleSequentialLog = sequentialLog;
- exports.scaleSequentialPow = sequentialPow;
- exports.scaleSequentialQuantile = sequentialQuantile;
- exports.scaleSequentialSqrt = sequentialSqrt;
- exports.scaleSequentialSymlog = sequentialSymlog;
- exports.scaleSqrt = sqrt;
- exports.scaleSymlog = symlog;
- exports.scaleThreshold = threshold;
- exports.scaleTime = time;
- exports.scaleUtc = utcTime;
- exports.tickFormat = tickFormat;
-
- Object.defineProperty(exports, '__esModule', { value: true });
-
- }));
|