当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Tensorflow.js tf.layers.convLstm2d()用法及代码示例


Tensorflow.js 是一个由 Google 开发的开源库,用于在浏览器或节点环境中运行机器学习模型以及深度学习神经网络。

tf.layers.convLstm2d() 函数用于创建一个 ConvRNN2D 层,该层由一个 ConvLSTM2DCell 组成,ConvLSTM2D 的 apply 方法对一系列输入进行操作。输入的形状至少需要是 4D,第一个维度是时间步长。 convLstm2d 是卷积 LSTM 层。

用法:

tf.layers.convLstm2d( args )

参数:

  • args: 它指定给定的配置对象:
    • activation: 这是要使用的激活函数。默认为双曲正切。如果传递 null,则不会使用激活函数。
    • useBias: 它指定是否使用偏差向量。
    • kernelInitializer: 它是核权重矩阵的初始化器,用于输入的线性变换。
    • recurrentInitializer: 它是recurrentInitializer权重矩阵的Initializer,用于循环状态的线性变换。
    • biasInitializer: 它是偏置向量的初始值设定项。
    • kernelRegularizer: 它是应用于核权重矩阵的正则化函数。
    • recurrentRegularizer: 它是应用于 recurrentKernel 权重矩阵的正则化函数。
    • biasRegularizer:  它是应用于偏置向量的正则化函数。
    • kernelConstraint: 它是应用于核权重矩阵的约束函数。
    • recurrentConstraint:  它是应用于 recurrentKernel 权重矩阵的约束函数。
    • biasConstraint: 它是应用于偏置向量的约束函数。
    • dropout: 它是 0 到 1 之间的数字,指示输入线性变换要丢弃的单位。
    • recurrentDropout: 它是降低循环状态线性变换的分数。
    • dropoutFunc: 这用于测试 DI。
    • inputShape: 它应该是一个数字数组。该字段用于创建一个输入层,该输入层用于插入到该层之前。
    • batchInputShape: 它应该是一个数字数组。如果提供 inputShape 和此字段作为创建用于插入到该图层之前的输入图层的参数,则将使用此字段。
    • batchSize: 它应该是一个数字。在没有batchInputShape的情况下,该字段用于使用inputShape创建batchInputShape。 batchInputShape:[batchSize,...inputShape]。
    • dtype: 如果该层用作输入层,则该字段用作该层的数据类型。
    • name: 它应该是字符串类型。该字段定义该层的名称。
    • trainable: 它应该是布尔值。该字段定义该层的权重是否可以通过拟合进行训练。
    • weights: 这应该是一个定义该层初始权重值的张量。
    • inputDType: 这是用于旧版支持的数据类型。
    • recurrentActivation:它指定将用于循环步骤的激活函数。该参数的默认值为硬 sigmoid。
    • unitForgetBias: 它应该是布尔值。它用于在初始化时将遗忘门的偏差加 1。
    • implementation: 它指定了实现模式。它可以是 1 或 2。为了获得卓越的性能,建议实施。
    • returnSequences:  它应该是布尔值。它定义了这两个天气最后输出或完整序列在输出序列中返回。
    • returnState: 它应该是布尔值。它定义输出中返回的最后状态。
    • goBackwards: 它应该是布尔值。它定义是否以相反和相反的顺序处理输入。
    • stateful: 它应该是布尔值。它定义是否使用批次的最后状态作为当前批次的初始状态。
    • unroll: 它应该是布尔值。它告诉是否使用展开的网络,否则使用符号循环。
    • inputDim: 它应该是一个数字。当该层用作模型的第一层时使用此选项。它定义了层中输入的维度。
    • inputLength: 它应该是一个数字。当输入数据的顺序恒定时,应使用此字段。
    • cell: 它应该是 RNN 单元的实例或 RNN 单元实例的数组。
    • filters: 它是多个滤波器的卷积。
    • kernelSize: 它是卷积窗口将具有的维度。
    • strides: 它是每个维度上卷积层的步长。
    • padding: 它应该是 '有效’,‘same’,‘causal’。它定义了填充模式。
    • dataFormat: 它定义了数据的格式,它告诉输入中维度的顺序。
    • dilationRate: 卷积层在每个维度上应扩张到的扩张率。

返回:它返回 ConvLSTM2D。

示例 1:在此示例中,我们将仅在一个输入中操作 apply 方法。

Javascript


// Config for input layer
const bSize = 3;
const sLength = 4;
const size = 7;
const channels = 2;
const inputShape = [bSize, sLength, size, size, channels];
const input = tf.zeros(inputShape);
// Config for convLstm2d 
const filters = 4;
const kernelSize = 4;
const layer = tf.layers.convLstm2d({filters, kernelSize});
const output = layer.apply(input);
// Printing Shape of our output
console.log(JSON.stringify(output.shape));

输出:

[3,4,4,4]

示例 2:

Javascript


import * as tf form "@tensorflow/tfjs"
const filters = 3;
const kernelSize = 3;
const batchSize = 4;
const sequenceLength = 2;
const size = 5;
const channels = 3;
const Input = tf.input({shape: [2, 3, 5, 4]});
const Data = tf.ones([1, 2, 3, 5, 4]);
const inputShape = [batchSize, 
    sequenceLength, size, size, channels];
const input = tf.ones(inputShape);
const layer = tf.layers.convLstm2d({filters, kernelSize});
const output = layer.apply(Input);
const model = tf.model({inputs: Input, outputs: output});
model.predict(Data).print();

输出:

Tensor
    [[[[0.2382042, 0.3073192, -0.0167814],
       [0.2362143, 0.3104056, -0.0188109],
       [0.2277206, 0.3124302, -0.0153713]]]]

参考:https://js.tensorflow.org/api/latest/#layers.convLstm2d



相关用法


注:本文由纯净天空筛选整理自satyam00so大神的英文原创作品 Tensorflow.js tf.layers.convLstm2d() Function。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。