| 1234567891011121314151617181920212223242526272829303132333435363738 |
- import {ascending, bisect, quantile} from "d3-array";
- import {identity} from "./continuous.js";
- import {initInterpolator} from "./init.js";
- export default function sequentialQuantile() {
- var domain = [],
- interpolator = identity;
- function scale(x) {
- if (x != null && !isNaN(x = +x)) return interpolator((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(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) => quantile(domain, i / n));
- };
- scale.copy = function() {
- return sequentialQuantile(interpolator).domain(domain);
- };
- return initInterpolator.apply(scale, arguments);
- }
|