UNPKG

@tensorflow/tfjs-node

Version:

This repository provides native TensorFlow execution in backend JavaScript applications under the Node.js runtime, accelerated by the TensorFlow C binary under the hood. It provides the same API as [TensorFlow.js](https://js.tensorflow.org/api/latest/).

104 lines (103 loc) 4.36 kB
"use strict"; /** * @license * Copyright 2019 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. * ============================================================================= */ Object.defineProperty(exports, "__esModule", { value: true }); var tfjs_1 = require("@tensorflow/tfjs"); var nodejs_kernel_backend_1 = require("./nodejs_kernel_backend"); var SummaryFileWriter = /** @class */ (function () { function SummaryFileWriter(resourceHandle) { this.resourceHandle = resourceHandle; nodejs_kernel_backend_1.ensureTensorflowBackend(); this.backend = nodejs_kernel_backend_1.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*. */ SummaryFileWriter.prototype.scalar = function (name, value, step, description) { // 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. */ SummaryFileWriter.prototype.flush = function () { this.backend.flushSummaryWriter(this.resourceHandle); }; return SummaryFileWriter; }()); exports.SummaryFileWriter = SummaryFileWriter; /** * 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. */ var summaryFileWriterCache = {}; /** * 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'} */ function summaryFileWriter(logdir, maxQueue, flushMillis, filenameSuffix) { if (maxQueue === void 0) { maxQueue = 10; } if (flushMillis === void 0) { flushMillis = 120000; } if (filenameSuffix === void 0) { filenameSuffix = '.v2'; } tfjs_1.util.assert(logdir != null && typeof logdir === 'string' && logdir.length > 0, function () { return "Invalid logdir: " + logdir + ". Expected a non-empty string for logdir."; }); if (!(logdir in summaryFileWriterCache)) { nodejs_kernel_backend_1.ensureTensorflowBackend(); var backend = nodejs_kernel_backend_1.nodeBackend(); var writerResource = backend.summaryWriter(logdir); backend.createSummaryFileWriter(writerResource, logdir, maxQueue, flushMillis, filenameSuffix); summaryFileWriterCache[logdir] = new SummaryFileWriter(writerResource); } return summaryFileWriterCache[logdir]; } exports.summaryFileWriter = summaryFileWriter;