UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

267 lines (260 loc) 33.1 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _utils = require("@kepler.gl/utils"); var _iterableTileSet = _interopRequireDefault(require("./iterable-tile-set")); var _tileUtils = require("./tile-utils"); function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project /** * Per-tile stats, for caching */ /** * Stateful class offering dataset-style functions for the set of tiles. */ var TileDataset = exports["default"] = /*#__PURE__*/function () { function TileDataset(accessors, tiles) { (0, _classCallCheck2["default"])(this, TileDataset); (0, _defineProperty2["default"])(this, "accessors", void 0); (0, _defineProperty2["default"])(this, "tiles", void 0); (0, _defineProperty2["default"])(this, "tileSet", void 0); (0, _defineProperty2["default"])(this, "tileIds", new Set()); /** Cache for per-tile field stats: tileId -> fieldId -> stats */ (0, _defineProperty2["default"])(this, "tileStats", new Map()); this.accessors = accessors; this.tiles = []; this.tileSet = new _iterableTileSet["default"]([], accessors.getRowCount); if (tiles) { this.updateTiles(tiles); } } /** * Invalidate the cached data */ return (0, _createClass2["default"])(TileDataset, [{ key: "invalidateCache", value: function invalidateCache() { // TODO: implement later } /** * Update the set of tiles in the viewport */ }, { key: "updateTiles", value: function updateTiles(tiles) { var _this$accessors = this.accessors, getTileId = _this$accessors.getTileId, getIterable = _this$accessors.getIterable, getRowCount = _this$accessors.getRowCount; var tileIds = new Set(tiles.map(getTileId)); if (!areEqualSets(tileIds, this.tileIds)) { this.invalidateCache(); } this.tiles = tiles; this.tileIds = tileIds; this.tileSet = new _iterableTileSet["default"](tiles.map(getIterable), getRowCount); } /** * Get the min/max domain of a field */ }, { key: "getExtent", value: function getExtent(field) { var _this$accessors2 = this.accessors, getRowValue = _this$accessors2.getRowValue, getIterable = _this$accessors2.getIterable; var accessor = getRowValue(field); var min = Infinity; var max = -Infinity; var _iterator = _createForOfIteratorHelper(this.tiles), _step; try { for (_iterator.s(); !(_step = _iterator.n()).done;) { var tile = _step.value; // Check the cache var extent = this.getTileStat(tile, field, 'extent'); if (!extent) { // Cache miss, calculate and cache extent = getTileExtent(getIterable(tile), field, accessor); this.setTileStat(tile, field, 'extent', extent); } if (extent) { if (extent[0] < min) min = extent[0]; if (extent[1] > max) max = extent[1]; } } } catch (err) { _iterator.e(err); } finally { _iterator.f(); } return Number.isFinite(min) && Number.isFinite(max) ? [min, max] : [0, 0]; } /** * Get a sample of field values to use in estimating quantiles */ }, { key: "getQuantileSample", value: function getQuantileSample(field) { var minRowCount = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1000; // TODO: There should be reasonable per-tile caching possible here var set = this.tileSet; var accessor = this.accessors.getRowValue(field); var sample = []; var sampleStep = Math.max(Math.floor(set.rowCount / minRowCount), 1); var i = 0; var _iterator2 = _createForOfIteratorHelper(set), _step2; try { for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) { var _row = _step2.value; if (++i === sampleStep) { var val = accessor(field, _row); if (val !== null) sample.push(val); i = 0; } } } catch (err) { _iterator2.e(err); } finally { _iterator2.f(); } (0, _utils.quickInsertionSort)(sample); (0, _tileUtils.pruneQuantiles)(sample); return sample; } /** * Get a set of unique values for a field */ }, { key: "getUniqueValues", value: function getUniqueValues(field) { var _this$accessors3 = this.accessors, getRowValue = _this$accessors3.getRowValue, getIterable = _this$accessors3.getIterable; var accessor = getRowValue(field); var uniques = new Set(); var _iterator3 = _createForOfIteratorHelper(this.tiles), _step3; try { for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) { var _tileUniques; var tile = _step3.value; // Check the cache var tileUniques = this.getTileStat(tile, field, 'uniqueValues'); if (!tileUniques) { // Cache miss, calculate and cache tileUniques = getTileUniqueValues(getIterable(tile), field, accessor); this.setTileStat(tile, field, 'uniqueValues', tileUniques); } var _iterator4 = _createForOfIteratorHelper((_tileUniques = tileUniques) !== null && _tileUniques !== void 0 ? _tileUniques : []), _step4; try { for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) { var val = _step4.value; uniques.add(val); } } catch (err) { _iterator4.e(err); } finally { _iterator4.f(); } } } catch (err) { _iterator3.e(err); } finally { _iterator3.f(); } return (0, _toConsumableArray2["default"])(uniques); } }, { key: "getTileStat", value: function getTileStat(tile, field, stat) { var _this$tileStats$get; return (_this$tileStats$get = this.tileStats.get(this.accessors.getTileId(tile))) === null || _this$tileStats$get === void 0 || (_this$tileStats$get = _this$tileStats$get.get(field.name)) === null || _this$tileStats$get === void 0 ? void 0 : _this$tileStats$get[stat]; } }, { key: "setTileStat", value: function setTileStat(tile, field, stat, value) { var _this$tileStats$get2, _tileStats$get; var tileId = this.accessors.getTileId(tile); var tileStats = (_this$tileStats$get2 = this.tileStats.get(tileId)) !== null && _this$tileStats$get2 !== void 0 ? _this$tileStats$get2 : new Map(); var tileFieldStats = (_tileStats$get = tileStats.get(field.name)) !== null && _tileStats$get !== void 0 ? _tileStats$get : {}; tileFieldStats[stat] = value; tileStats.set(field.name, tileFieldStats); this.tileStats.set(tileId, tileStats); } }]); }(); /** * Get the min/max domain of a field in a given tile */ function getTileExtent(iterable, field, accessor) { var min = Infinity; var max = -Infinity; var _iterator5 = _createForOfIteratorHelper(iterable), _step5; try { for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) { var _row2 = _step5.value; var val = accessor(field, _row2); if (val === null) continue; if (val < min) min = val; if (val > max) max = val; } } catch (err) { _iterator5.e(err); } finally { _iterator5.f(); } return Number.isFinite(min) && Number.isFinite(max) ? [min, max] : undefined; } /** * Get unique values for a field in a given tile */ function getTileUniqueValues(iterable, field, accessor) { var maxUniques = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 20; var uniques = new Set(); var _iterator6 = _createForOfIteratorHelper(iterable), _step6; try { for (_iterator6.s(); !(_step6 = _iterator6.n()).done;) { var _row3 = _step6.value; if (uniques.size >= maxUniques) return uniques; uniques.add(accessor(field, _row3)); } } catch (err) { _iterator6.e(err); } finally { _iterator6.f(); } return uniques; } function areEqualSets(a, b) { if (a.size !== b.size) return false; var _iterator7 = _createForOfIteratorHelper(a), _step7; try { for (_iterator7.s(); !(_step7 = _iterator7.n()).done;) { var val = _step7.value; if (!b.has(val)) { return false; } } } catch (err) { _iterator7.e(err); } finally { _iterator7.f(); } return true; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_utils","require","_iterableTileSet","_interopRequireDefault","_tileUtils","_createForOfIteratorHelper","r","e","t","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","_n","F","s","n","done","value","f","TypeError","o","a","u","call","next","_arrayLikeToArray","toString","slice","constructor","name","from","test","TileDataset","exports","accessors","tiles","_classCallCheck2","_defineProperty2","Set","Map","tileSet","IterableTileSet","getRowCount","updateTiles","_createClass2","key","invalidateCache","_this$accessors","getTileId","getIterable","tileIds","map","areEqualSets","getExtent","field","_this$accessors2","getRowValue","accessor","min","Infinity","max","_iterator","_step","tile","extent","getTileStat","getTileExtent","setTileStat","err","Number","isFinite","getQuantileSample","minRowCount","arguments","undefined","set","sample","sampleStep","Math","floor","rowCount","i","_iterator2","_step2","row","val","push","quickInsertionSort","pruneQuantiles","getUniqueValues","_this$accessors3","uniques","_iterator3","_step3","_tileUniques","tileUniques","getTileUniqueValues","_iterator4","_step4","add","_toConsumableArray2","stat","_this$tileStats$get","tileStats","get","_this$tileStats$get2","_tileStats$get","tileId","tileFieldStats","iterable","_iterator5","_step5","maxUniques","_iterator6","_step6","size","b","_iterator7","_step7","has"],"sources":["../../../src/vector-tile/common-tile/tile-dataset.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {Field as KeplerField} from '@kepler.gl/types';\nimport {quickInsertionSort} from '@kepler.gl/utils';\n\nimport IterableTileSet, {RowCountAccessor} from './iterable-tile-set';\nimport {pruneQuantiles} from './tile-utils';\n\nexport type Datum = number | string | null;\n\ntype RowValueAccessor<T> = (\n  field: KeplerField,\n  row: T extends Iterable<infer V> ? V : never\n) => Datum;\ntype RowValueAccessorFactory<T> = (\n  field?: KeplerField,\n  indexKey?: number | null\n) => RowValueAccessor<T>;\n\ntype TileAccessors<T, I extends Iterable<any> = T extends Iterable<any> ? T : never> = {\n  getTileId: (tile: T) => string;\n  getIterable: (tile: T) => I;\n  getRowCount: RowCountAccessor<I>;\n  getRowValue: RowValueAccessorFactory<I>;\n};\n\n/**\n * Per-tile stats, for caching\n */\ntype TileFieldStats = {\n  extent?: [number, number];\n  sample?: Datum[];\n  uniqueValues?: Set<Datum>;\n};\n\n/**\n * Stateful class offering dataset-style functions for the set of tiles.\n */\nexport default class TileDataset<T, I extends Iterable<any> = T extends Iterable<any> ? T : never> {\n  private accessors: TileAccessors<T, I>;\n  private tiles: readonly T[];\n  private tileSet: IterableTileSet<I>;\n  private tileIds: Set<string> = new Set();\n\n  /** Cache for per-tile field stats: tileId -> fieldId -> stats */\n  private tileStats: Map<string, Map<string, TileFieldStats>> = new Map();\n\n  constructor(accessors: TileAccessors<T, I>, tiles?: readonly T[]) {\n    this.accessors = accessors;\n    this.tiles = [];\n    this.tileSet = new IterableTileSet([], accessors.getRowCount);\n    if (tiles) {\n      this.updateTiles(tiles);\n    }\n  }\n\n  /**\n   * Invalidate the cached data\n   */\n  invalidateCache(): void {\n    // TODO: implement later\n  }\n\n  /**\n   * Update the set of tiles in the viewport\n   */\n  updateTiles(tiles: readonly T[]): void {\n    const {getTileId, getIterable, getRowCount} = this.accessors;\n    const tileIds = new Set<string>(tiles.map(getTileId));\n    if (!areEqualSets(tileIds, this.tileIds)) {\n      this.invalidateCache();\n    }\n    this.tiles = tiles;\n    this.tileIds = tileIds;\n    this.tileSet = new IterableTileSet(tiles.map(getIterable), getRowCount);\n  }\n\n  /**\n   * Get the min/max domain of a field\n   */\n  getExtent(field: KeplerField): [number, number] {\n    const {getRowValue, getIterable} = this.accessors;\n    const accessor = getRowValue(field);\n    let min = Infinity;\n    let max = -Infinity;\n\n    for (const tile of this.tiles) {\n      // Check the cache\n      let extent = this.getTileStat(tile, field, 'extent');\n      if (!extent) {\n        // Cache miss, calculate and cache\n        extent = getTileExtent(getIterable(tile), field, accessor);\n        this.setTileStat(tile, field, 'extent', extent);\n      }\n      if (extent) {\n        if (extent[0] < min) min = extent[0];\n        if (extent[1] > max) max = extent[1];\n      }\n    }\n    return Number.isFinite(min) && Number.isFinite(max) ? [min, max] : [0, 0];\n  }\n\n  /**\n   * Get a sample of field values to use in estimating quantiles\n   */\n  getQuantileSample(field: KeplerField, minRowCount = 1000): number[] {\n    // TODO: There should be reasonable per-tile caching possible here\n    const set = this.tileSet;\n    const accessor = this.accessors.getRowValue(field);\n    const sample: number[] = [];\n    const sampleStep = Math.max(Math.floor(set.rowCount / minRowCount), 1);\n    let i = 0;\n    for (const row of set) {\n      if (++i === sampleStep) {\n        const val = accessor(field, row) as number | null;\n        if (val !== null) sample.push(val);\n        i = 0;\n      }\n    }\n    quickInsertionSort(sample);\n    pruneQuantiles(sample);\n    return sample;\n  }\n\n  /**\n   * Get a set of unique values for a field\n   */\n  getUniqueValues(field: KeplerField): Datum[] {\n    const {getRowValue, getIterable} = this.accessors;\n    const accessor = getRowValue(field);\n    const uniques = new Set<Datum>();\n\n    for (const tile of this.tiles) {\n      // Check the cache\n      let tileUniques = this.getTileStat(tile, field, 'uniqueValues');\n      if (!tileUniques) {\n        // Cache miss, calculate and cache\n        tileUniques = getTileUniqueValues(getIterable(tile), field, accessor);\n        this.setTileStat(tile, field, 'uniqueValues', tileUniques);\n      }\n      for (const val of tileUniques ?? []) {\n        uniques.add(val);\n      }\n    }\n    return [...uniques];\n  }\n\n  private getTileStat<K extends keyof TileFieldStats>(\n    tile: T,\n    field: KeplerField,\n    stat: K\n  ): TileFieldStats[K] {\n    return this.tileStats.get(this.accessors.getTileId(tile))?.get(field.name)?.[stat];\n  }\n\n  private setTileStat<K extends keyof TileFieldStats>(\n    tile: T,\n    field: KeplerField,\n    stat: K,\n    value: TileFieldStats[K]\n  ): void {\n    const tileId = this.accessors.getTileId(tile);\n    const tileStats = this.tileStats.get(tileId) ?? new Map();\n    const tileFieldStats = tileStats.get(field.name) ?? {};\n    tileFieldStats[stat] = value;\n    tileStats.set(field.name, tileFieldStats);\n    this.tileStats.set(tileId, tileStats);\n  }\n}\n\n/**\n * Get the min/max domain of a field in a given tile\n */\nfunction getTileExtent<I extends Iterable<any>>(\n  iterable: I,\n  field: KeplerField,\n  accessor: RowValueAccessor<I>\n): [number, number] | undefined {\n  let min = Infinity;\n  let max = -Infinity;\n  for (const row of iterable) {\n    const val = accessor(field, row) as number | null;\n    if (val === null) continue;\n    if (val < min) min = val;\n    if (val > max) max = val;\n  }\n  return Number.isFinite(min) && Number.isFinite(max) ? [min, max] : undefined;\n}\n\n/**\n * Get unique values for a field in a given tile\n */\nfunction getTileUniqueValues<I extends Iterable<any>>(\n  iterable: I,\n  field: KeplerField,\n  accessor: RowValueAccessor<I>,\n  maxUniques = 20\n): Set<Datum> {\n  const uniques = new Set<Datum>();\n  for (const row of iterable) {\n    if (uniques.size >= maxUniques) return uniques;\n    uniques.add(accessor(field, row));\n  }\n  return uniques;\n}\n\nfunction areEqualSets(a: Set<string>, b: Set<string>): boolean {\n  if (a.size !== b.size) return false;\n  for (const val of a) {\n    if (!b.has(val)) {\n      return false;\n    }\n  }\n  return true;\n}\n"],"mappings":"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","ignoreList":[]}