forked from tensorflow/tfjs-core
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpool_benchmarks.ts
93 lines (79 loc) · 2.9 KB
/
pool_benchmarks.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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
/**
* @license
* Copyright 2017 Google Inc. All Rights Reserved.
* 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 * as tf from '@tensorflow/tfjs-core';
import {BenchmarkTest} from './types';
import * as benchmark_util from './util';
const CPU_OP_RUNS = 1;
export interface PoolBenchmarkParams {
depth: number;
fieldSize: number;
stride: number;
}
function getPoolingOp(option: string): (
x: tf.Tensor3D, filterSize: [number, number]|number,
strides: [number, number]|number) => tf.Tensor3D {
switch (option) {
case 'max':
return (x: tf.Tensor3D, filterSize: [number, number]|number,
strides: [number, number]|number) => {
return x.maxPool(filterSize, strides, 'same');
};
case 'avg':
return (x: tf.Tensor3D, filterSize: [number, number]|number,
strides: [number, number]|number) => {
return x.avgPool(filterSize, strides, 'same');
};
default:
throw new Error(`Not found such ops: ${option}`);
}
}
export class PoolCPUBenchmark implements BenchmarkTest {
run(size: number, option: string,
params: PoolBenchmarkParams): Promise<number> {
tf.setBackend('cpu');
const outputDepth = params.depth;
const xShape: [number, number, number] = [size, size, outputDepth];
const fieldSize = params.fieldSize;
const stride = params.stride;
const op = getPoolingOp(option);
const x: tf.Tensor3D = tf.randomUniform(xShape, -1, 1);
const start = performance.now();
for (let i = 0; i < CPU_OP_RUNS; i++) {
op(x, fieldSize, stride);
}
const avgTime = (performance.now() - start) / CPU_OP_RUNS;
return new Promise<number>((resolve, reject) => {
resolve(avgTime);
});
}
}
export class PoolGPUBenchmark implements BenchmarkTest {
async run(size: number, option: string, params: PoolBenchmarkParams):
Promise<number> {
tf.setBackend('webgl');
const outputDepth = params.depth;
const xShape: [number, number, number] = [size, size, outputDepth];
const fieldSize = params.fieldSize;
const stride = params.stride;
const x: tf.Tensor3D = tf.randomUniform(xShape, -1, 1);
const op = getPoolingOp(option);
const benchmark = () => op(x, fieldSize, stride);
const time = await benchmark_util.warmupAndBenchmarkGPU(benchmark);
x.dispose();
return time;
}
}