Skip to content

Commit

Permalink
type improvements
Browse files Browse the repository at this point in the history
  • Loading branch information
Pessimistress committed Jun 10, 2024
1 parent 2f790c7 commit a9f0504
Show file tree
Hide file tree
Showing 5 changed files with 21 additions and 24 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,12 @@ import {WebGLBinSorter} from './webgl-bin-sorter';
import {WebGLAggregationTransform} from './webgl-aggregation-transform';
import {_deepEqual as deepEqual, log, BinaryAttribute} from '@deck.gl/core';

import type {Aggregator, AggregationProps} from '../aggregator';
import type {Aggregator, AggregationProps, AggregatedBin} from '../aggregator';
import type {Device, Buffer, BufferLayout, TypedArray} from '@luma.gl/core';
import type {ShaderModule} from '@luma.gl/shadertools';

/** Settings used to construct a new GPUAggregator */
export type GPUAggregatorSettings = {
/** Options used to construct a new GPUAggregator */
export type GPUAggregatorOptions = {
/** Size of bin IDs */
dimensions: 1 | 2;
/** How many properties to perform aggregation on */
Expand All @@ -32,7 +32,7 @@ export type GPUAggregatorSettings = {
defines?: Record<string, string | number | boolean>;
};

/** Options used to run GPU aggregation, can be changed at any time */
/** Props used to run GPU aggregation, can be changed at any time */
export type GPUAggregationProps = AggregationProps & {
/** Limits of binId defined for each dimension. Ids outside of the [start, end) are ignored.
*/
Expand Down Expand Up @@ -71,7 +71,7 @@ export class GPUAggregator implements Aggregator {
/** Step 2. (optional) calculate the min/max across all bins */
protected aggregationTransform: WebGLAggregationTransform;

constructor(device: Device, settings: GPUAggregatorSettings) {
constructor(device: Device, settings: GPUAggregatorOptions) {
this.device = device;
this.dimensions = settings.dimensions;
this.numChannels = settings.numChannels;
Expand Down Expand Up @@ -103,22 +103,15 @@ export class GPUAggregator implements Aggregator {
}

/** Returns the information for a given bin. */
getBin(index: number): {
/** The original id */
id: number | [number, number];
/** Aggregated values by channel */
value: number[];
/** Count of data points in this bin */
count: number;
} | null {
getBin(index: number): AggregatedBin | null {
if (index < 0 || index >= this.numBins) {
return null;
}
const {binIdRange} = this.props;
let id: number | [number, number];
let id: number[];

if (this.dimensions === 1) {
id = index + binIdRange[0][0];
id = [index + binIdRange[0][0]];
} else {
const [[x0, x1], [y0]] = binIdRange;
const width = x1 - x0;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import {BufferTransform} from '@luma.gl/engine';
import {glsl, createRenderTarget} from './utils';

import type {Device, Framebuffer, Buffer, Texture} from '@luma.gl/core';
import type {GPUAggregatorSettings} from './gpu-aggregator';
import type {GPUAggregatorOptions} from './gpu-aggregator';
import type {AggregationOperation} from '../aggregator';

import {TEXTURE_WIDTH} from './webgl-bin-sorter';
Expand All @@ -26,7 +26,7 @@ export class WebGLAggregationTransform {
/** Aggregated [min, max] for each channel */
private _domains: [min: number, max: number][] | null = null;

constructor(device: Device, settings: GPUAggregatorSettings) {
constructor(device: Device, settings: GPUAggregatorOptions) {
this.device = device;
this.numChannels = settings.numChannels;
this.transform = createTransform(device, settings);
Expand Down Expand Up @@ -112,7 +112,7 @@ export class WebGLAggregationTransform {
}
}

function createTransform(device: Device, settings: GPUAggregatorSettings): BufferTransform {
function createTransform(device: Device, settings: GPUAggregatorOptions): BufferTransform {
const vs = glsl`\
#version 300 es
#define SHADER_NAME gpu-aggregation-domain-vertex
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import {Model, ModelProps} from '@luma.gl/engine';
import {glsl, createRenderTarget} from './utils';

import type {Device, Framebuffer, Texture} from '@luma.gl/core';
import type {GPUAggregatorSettings} from './gpu-aggregator';
import type {GPUAggregatorOptions} from './gpu-aggregator';
import type {AggregationOperation} from '../aggregator';

const COLOR_CHANNELS = [0x1, 0x2, 0x4, 0x8]; // GPU color mask RED, GREEN, BLUE, ALPHA
Expand Down Expand Up @@ -30,7 +30,7 @@ export class WebGLBinSorter {
*/
private binsFBO: Framebuffer | null = null;

constructor(device: Device, settings: GPUAggregatorSettings) {
constructor(device: Device, settings: GPUAggregatorOptions) {
this.device = device;
this.model = createModel(device, settings);
}
Expand Down Expand Up @@ -175,7 +175,7 @@ function getMaskByOperation(
return result;
}

function createModel(device: Device, settings: GPUAggregatorSettings): Model {
function createModel(device: Device, settings: GPUAggregatorOptions): Model {
let userVs = settings.vs;

if (settings.dimensions === 2) {
Expand Down
2 changes: 1 addition & 1 deletion modules/aggregation-layers/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -46,5 +46,5 @@ export type {ScreenGridLayerProps} from './screen-grid-layer/screen-grid-layer';

export type {
GPUAggregationProps,
GPUAggregatorSettings
GPUAggregatorOptions
} from './aggregation-layer-v9/gpu-aggregator/gpu-aggregator';
Original file line number Diff line number Diff line change
Expand Up @@ -158,11 +158,15 @@ test('GPUAggregator#1D', t => {
t.deepEqual(aggregator.getResultDomain(2), [1, 5], 'getResultDomain() - max education');

// Empty bin
t.deepEqual(aggregator.getBin(0), {id: 2, count: 0, value: [NaN, NaN, NaN]}, 'getBin() - empty');
t.deepEqual(
aggregator.getBin(0),
{id: [2], count: 0, value: [NaN, NaN, NaN]},
'getBin() - empty'
);
// {age: 40, household: 4, income: 140, education: 4},
// {age: 42, household: 2, income: 110, education: 5},
// {age: 44, household: 4, income: 500, education: 4},
t.deepEqual(aggregator.getBin(6), {id: 8, count: 3, value: [3, 250, 5]}, 'getBin()');
t.deepEqual(aggregator.getBin(6), {id: [8], count: 3, value: [3, 250, 5]}, 'getBin()');

attributes.age.delete();
attributes.income.delete();
Expand Down

0 comments on commit a9f0504

Please sign in to comment.