sequentialQuantile.js 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738
  1. import {ascending, bisect, quantile} from "d3-array";
  2. import {identity} from "./continuous.js";
  3. import {initInterpolator} from "./init.js";
  4. export default function sequentialQuantile() {
  5. var domain = [],
  6. interpolator = identity;
  7. function scale(x) {
  8. if (x != null && !isNaN(x = +x)) return interpolator((bisect(domain, x, 1) - 1) / (domain.length - 1));
  9. }
  10. scale.domain = function(_) {
  11. if (!arguments.length) return domain.slice();
  12. domain = [];
  13. for (let d of _) if (d != null && !isNaN(d = +d)) domain.push(d);
  14. domain.sort(ascending);
  15. return scale;
  16. };
  17. scale.interpolator = function(_) {
  18. return arguments.length ? (interpolator = _, scale) : interpolator;
  19. };
  20. scale.range = function() {
  21. return domain.map((d, i) => interpolator(i / (domain.length - 1)));
  22. };
  23. scale.quantiles = function(n) {
  24. return Array.from({length: n + 1}, (_, i) => quantile(domain, i / n));
  25. };
  26. scale.copy = function() {
  27. return sequentialQuantile(interpolator).domain(domain);
  28. };
  29. return initInterpolator.apply(scale, arguments);
  30. }