forked from tensorflow/tfjs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtensorboard.ts
112 lines (100 loc) · 3.79 KB
/
tensorboard.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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
/**
* @license
* Copyright 2019 Google LLC. 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 {Scalar, Tensor, util} from '@tensorflow/tfjs';
import {ensureTensorflowBackend, nodeBackend, NodeJSKernelBackend} from './nodejs_kernel_backend';
export class SummaryFileWriter {
backend: NodeJSKernelBackend;
constructor(private readonly resourceHandle: Tensor) {
ensureTensorflowBackend();
this.backend = nodeBackend();
}
/**
* Write a scalar summary.
*
* @param name A name of the summary. The summary tag for TensorBoard will be
* this name.
* @param value A real numeric scalar value, as `tf.Scalar` or a JavaScript
* `number`.
* @param step Required `int64`-castable, monotically-increasing step value.
* @param description Optinal long-form description for this summary, as a
* `string`. *Not implemented yet*.
*/
scalar(
name: string, value: Scalar|number, step: number, description?: string) {
// N.B.: Unlike the Python TensorFlow API, step is a required parameter,
// because the construct of global step does not exist in TensorFlow.js.
if (description != null) {
throw new Error('scalar() does not support description yet');
}
this.backend.writeScalarSummary(this.resourceHandle, step, name, value);
}
/**
* Force summary writer to send all buffered data to storage.
*/
flush() {
this.backend.flushSummaryWriter(this.resourceHandle);
}
}
/**
* Use a cache for `SummaryFileWriter` instance.
*
* Using multiple instances of `SummaryFileWriter` pointing to the same
* logdir has potential problems. Using this cache avoids those problems.
*/
const summaryFileWriterCache: {[logdir: string]: SummaryFileWriter} = {};
/**
* Create a summary file writer for TensorBoard.
*
* Example:
* ```js
* const tf = require('@tensorflow/tfjs-node');
*
* const summaryWriter = tf.node.summaryFileWriter('/tmp/tfjs_tb_logdir');
*
* for (let step = 0; step < 100; ++step) {
* summaryWriter.scalar('dummyValue', Math.sin(2 * Math.PI * step / 8), step);
* }
* ```
*
* @param logdir Log directory in which the summary data will be written.
* @param maxQueue Maximum queue length (default: `10`).
* @param flushMillis Flush every __ milliseconds (default: `120e3`, i.e,
* `120` seconds).
* @param filenameSuffix Suffix of the protocol buffer file names to be
* written in the `logdir` (default: `.v2`).
* @returns An instance of `SummaryFileWriter`.
*/
/**
* @doc {heading: 'TensorBoard', namespace: 'node'}
*/
export function summaryFileWriter(
logdir: string, maxQueue = 10, flushMillis = 120000,
filenameSuffix = '.v2'): SummaryFileWriter {
util.assert(
logdir != null && typeof logdir === 'string' && logdir.length > 0,
() =>
`Invalid logdir: ${logdir}. Expected a non-empty string for logdir.`);
if (!(logdir in summaryFileWriterCache)) {
ensureTensorflowBackend();
const backend = nodeBackend();
const writerResource = backend.summaryWriter(logdir);
backend.createSummaryFileWriter(
writerResource, logdir, maxQueue, flushMillis, filenameSuffix);
summaryFileWriterCache[logdir] = new SummaryFileWriter(writerResource);
}
return summaryFileWriterCache[logdir];
}