Tensorflow.js 是 Google 开发的一个开源库,用于在浏览器或节点环境中运行机器学习模型和深度学习神经网络。 Tensorflow.js tf.LayersModel 类 .fitDataset() 方法用于使用数据集对象训练层模型。
用法:
LayerModel.fitDataset(dataset, args);
参数:此方法接受以下参数:
- dataset:它是我们训练层模型的数据集形式的输入值。
- args:它是一个包含以下值的对象:
- batchesPerEpoch:它是每个时期的批次数。它取决于批次的大小,随着批次大小的增加而减小。
- epochs:它是训练模型期间训练数据集中的总迭代次数。它应该是一个整数值。
- initialEpoch:它用于定义开始训练的纪元值。
- validationData:它用于在最终模型之间进行选择时给出最终模型的估计。
- verbose:它有助于显示每个时期的进度。如果值为 0 - 表示在 fit() 调用期间没有打印消息。如果值为 1 - 这意味着在 Node.js 中,它会打印进度条。在浏览器中,它不显示任何操作。值 1 是默认值。 2 - 值 2 尚未实现。
- classWeight:它用于对损失函数进行加权。告诉模型更多地关注来自 under-represented 类的样本会很有用。
- callbacks:它定义了在训练期间要调用的回调列表。变量可以有一个或多个这些回调onTrainBegin()、onTrainEnd()、onEpochBegin()、onEpochEnd()、onBatchBegin()、onBatchEnd()、onYield()。
- validationBatchSize:它是定义批次大小的数字。它用于验证批量大小。这意味着我们不能一次性放置超过这个值的所有数据集。其默认值为 32。
- validationBatches:它用于验证批次的样品。它用于在 epoch 的每一端绘制验证数据以进行验证。
- yieldEvery:它定义了将主线程交给其他任务的频率的配置。它可以是自动的,这意味着屈服发生在一定的帧率下。批次,如果值是这个,它会产生每个批次。 epoch,如果值是这个,它产生每个纪元。任何数字,如果该值是任何数字,它会产生每个数字毫秒。从不,如果值是这个,它永远不会产生。
返回值:承诺<历史>
范例1:在本例中,我们将使用 CSV 数据集训练我们的层模型。
Javascript
import * as tf from "@tensorflow/tfjs"
// Path for the CSV file
const gfg_CsvFile =
'https://storage.googleapis.com/tfjs-examples/multivariate-linear-regression/data/boston-housing-train.csv';
async function run() {
// Creating model
const gfg_LayerModel = tf.sequential();
// Adding layer to model
const config = { units:1, inputShape:[12] }
const gfg_layer = tf.layers.dense(config);
gfg_LayerModel.add(gfg_layer);
// Compiling the model
const opt = tf.train.sgd(0.00000001)
gfg_LayerModel.compile({ optimizer:opt,
loss:'meanSquaredError' });
// Here we want to predict column tax
const config2 = { columnConfigs:{
rad:{ isLabel:true } } };
const csvDataset = tf.data.csv(gfg_CsvFile, config2);
// Creating dataset for training
const flattenedDataset =
csvDataset.map(({ xs, ys }) => {
return { xs:Object.values(xs),
ys:Object.values(ys) };
}).batch(6);
// Training the model
const Tm = await gfg_LayerModel.fitDataset(
flattenedDataset, { epochs:10 });
for (let i = 0; i < 6; i++) {
console.log(Tm.history.loss[i])
}
}
run();
输出:
41480.109375 28887.93359375 20162.228515625 14115.478515625 9924.9404296875 7020.56005859375
范例2:在这个例子中,我们将用数组的数据集训练我们的层模型。
Javascript
import * as tf from "@tensorflow/tfjs"
async function run() {
// Creating Layer model
const gfg_LayerModel = tf.sequential();
// Adding layer to model
const config = { units:4, inputShape:[4] }
const gfg_layer = tf.layers.dense(config);
gfg_LayerModel.add(gfg_layer);
// Compiling the model
const config2 = { optimizer:'sgd', loss:'meanSquaredError' }
gfg_LayerModel.compile(config2);
// Creating Datasets for training
const array1 = [
[1, 2, 3, 4],
[1, 4, 6, 8],
[1, 3, 4, 7],
[3, 4, 7, 8]
];
const array2 = [1, 1, 1, 1];
const arrData1 = tf.data.array(array1);
const arrData2 = tf.data.array(array2);
const config3 = { xs:arrData1, ys:arrData2 }
const arrayDataset = tf.data.zip(config3)
const ArrayDataset = arrayDataset.batch(4);
// Training the model
const Tm = await gfg_LayerModel.fitDataset(
ArrayDataset, { epochs:4 });
// Printing the loss after training
console.log("Loss After Training Layer Model"
+ Tm.history.loss[0]);
}
run();
输出:
Loss After Training Layer Model 4.386415958404541
参考:https://js.tensorflow.org/api/latest/#tf.LayersModel.fitDataset
相关用法
- Tensorflow.js tf.Sequential.fitDataset()用法及代码示例
- Tensorflow.js tf.Tensor.buffer()用法及代码示例
- Java String repeat()用法及代码示例
- Tensorflow.js tf.LayersModel.evaluate()用法及代码示例
- Tensorflow.js tf.data.Dataset.batch()用法及代码示例
- Tensorflow.js tf.Sequential.add()用法及代码示例
注:本文由纯净天空筛选整理自satyam00so大神的英文原创作品 Tensorflow.js tf.LayersModel class .fitDataset() Method。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。