-
Notifications
You must be signed in to change notification settings - Fork 302
/
Copy pathhash_table.benchmark.ts
36 lines (34 loc) · 1.19 KB
/
hash_table.benchmark.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
/**
* @license
* Copyright 2016 Google Inc.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { describe, bench } from "vitest";
import { HashSetUint64 } from "#src/gpu_hash/hash_table.js";
import { getRandomValues } from "#src/util/random.js";
import { Uint64 } from "#src/util/uint64.js";
describe("gpu_hash/hash_table", () => {
const ht = new HashSetUint64();
const numValues = 100;
const values = new Uint32Array(numValues * 2);
const temp = new Uint64();
getRandomValues(values);
bench("insert", () => {
ht.clear();
for (let i = 0, length = values.length; i < length; i += 2) {
temp.low = values[i];
temp.high = values[i + 1];
ht.add(temp);
}
});
});