Node.js 设置

对于 Node.js 环境,您可以使用 npm 安装它:

npm install @tensorflow/tfjs

2. 构建简单的神经网络模型

让我们创建一个简单的神经网络来预测基本线性函数 y = 2x - 1 的输出。我们将使用 TensorFlow.js 来创建和训练该模型。

第 1 步:定义模型

我们首先定义一个具有一个密集层的顺序模型(线性堆栈):

// Import TensorFlow.jsimport * as tf from \\'@tensorflow/tfjs\\';// Create a simple sequential modelconst model = tf.sequential();// Add a single dense layer with 1 unit (neuron)model.add(tf.layers.dense({units: 1, inputShape: [1]}));

在这里,我们创建了一个具有一个密集层的模型。该层有一个神经元(单位:1),并且需要一个输入特征(inputShape:[1])。

第 2 步:编译模型

接下来,我们通过指定优化器和损失函数来编译模型:

// Compile the modelmodel.compile({  optimizer: \\'sgd\\',  // Stochastic Gradient Descent  loss: \\'meanSquaredError\\'  // Loss function for regression});

我们使用随机梯度下降(SGD)优化器,这对于小模型是有效的。损失函数meanSquaredError适用于像这样的回归任务。

第 3 步:准备训练数据

我们现在将为函数 y = 2x - 1 创建一些训练数据。在 TensorFlow.js 中,数据存储在张量(多维数组)中。以下是我们生成一些训练数据的方法:

// Generate some synthetic data for trainingconst xs = tf.tensor2d([0, 1, 2, 3, 4], [5, 1]);  // Inputs (x values)const ys = tf.tensor2d([1, 3, 5, 7, 9], [5, 1]);  // Outputs (y values)

在本例中,我们创建了一个输入值 (0, 1, 2, 3, 4) 的张量 xs 和一个相应的输出张量 ys,其值使用 y = 2x - 1 计算。

第 4 步:训练模型

现在,我们可以根据我们的数据训练模型:

// Train the modelmodel.fit(xs, ys, {epochs: 500}).then(() => {  // Once training is complete, use the model to make predictions  model.predict(tf.tensor2d([5], [1, 1])).print();  // Output will be close to 2*5 - 1 = 9});

在这里,我们对模型进行 500 轮训练(训练数据的迭代)。训练后,我们使用模型来预测输入值为 5 的输出,该输出应返回接近 9 的值 (y = 2*5 - 1 = 9)。

3. 在浏览器中运行模型

要在浏览器中运行此模型,您需要一个包含 TensorFlow.js 库和 JavaScript 代码的 HTML 文件:

            TensorFlow.js Example              

Simple Neural Network with TensorFlow.js

并且在您的 app.js 文件中,您可以包含上面的模型构建和训练代码。

","image":"http://www.luping.net/uploads/20241022/17295980466717925ed5c04.jpg","datePublished":"2024-11-05T22:45:47+08:00","dateModified":"2024-11-05T22:45:47+08:00","author":{"@type":"Person","name":"luping.net","url":"https://www.luping.net/articlelist/0_1.html"}}
”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > JavaScript 机器学习入门:TensorFlow.js 初学者指南

JavaScript 机器学习入门:TensorFlow.js 初学者指南

发布于2024-11-05
浏览:929

Getting Started with Machine Learning in JavaScript: A Beginner’s Guide with TensorFlow.js

机器学习 (ML) 迅速改变了软件开发世界。直到最近,得益于 TensorFlow 和 PyTorch 等库,Python 仍是 ML 领域的主导语言。但随着 TensorFlow.js 的兴起,JavaScript 开发人员现在可以深入令人兴奋的机器学习世界,使用熟悉的语法直接在浏览器或 Node.js 上构建和训练模型。

在这篇博文中,我们将探讨如何开始使用 JavaScript 进行机器学习。我们将演练使用 TensorFlow.js.

构建和训练简单模型的示例

为什么选择 TensorFlow.js?

TensorFlow.js 是一个开源库,允许您完全用 JavaScript 定义、训练和运行机器学习模型。它既可以在浏览器中运行,也可以在 Node.js 上运行,这使得它对于各种 ML 应用程序具有难以置信的多功能性。

以下是 TensorFlow.js 令人兴奋的几个原因:

  1. 实时训练:您可以直接在浏览器中运行模型,提供实时交互。
  2. 跨平台:相同的代码可以在服务器和客户端环境上运行。
  3. 硬件加速:它使用WebGL进行GPU加速,从而加快计算速度。

让我们看看如何开始!

1. 设置 TensorFlow.js

在深入研究代码之前,您需要安装TensorFlow.js。您可以通过

浏览器设置

要在浏览器中使用 TensorFlow.js,只需在 HTML 文件中包含以下


Node.js 设置

对于 Node.js 环境,您可以使用 npm 安装它:

npm install @tensorflow/tfjs

2. 构建简单的神经网络模型

让我们创建一个简单的神经网络来预测基本线性函数 y = 2x - 1 的输出。我们将使用 TensorFlow.js 来创建和训练该模型。

第 1 步:定义模型

我们首先定义一个具有一个密集层的顺序模型(线性堆栈):

// Import TensorFlow.js
import * as tf from '@tensorflow/tfjs';

// Create a simple sequential model
const model = tf.sequential();

// Add a single dense layer with 1 unit (neuron)
model.add(tf.layers.dense({units: 1, inputShape: [1]}));

在这里,我们创建了一个具有一个密集层的模型。该层有一个神经元(单位:1),并且需要一个输入特征(inputShape:[1])。

第 2 步:编译模型

接下来,我们通过指定优化器和损失函数来编译模型:

// Compile the model
model.compile({
  optimizer: 'sgd',  // Stochastic Gradient Descent
  loss: 'meanSquaredError'  // Loss function for regression
});

我们使用随机梯度下降(SGD)优化器,这对于小模型是有效的。损失函数meanSquaredError适用于像这样的回归任务。

第 3 步:准备训练数据

我们现在将为函数 y = 2x - 1 创建一些训练数据。在 TensorFlow.js 中,数据存储在张量(多维数组)中。以下是我们生成一些训练数据的方法:

// Generate some synthetic data for training
const xs = tf.tensor2d([0, 1, 2, 3, 4], [5, 1]);  // Inputs (x values)
const ys = tf.tensor2d([1, 3, 5, 7, 9], [5, 1]);  // Outputs (y values)

在本例中,我们创建了一个输入值 (0, 1, 2, 3, 4) 的张量 xs 和一个相应的输出张量 ys,其值使用 y = 2x - 1 计算。

第 4 步:训练模型

现在,我们可以根据我们的数据训练模型:

// Train the model
model.fit(xs, ys, {epochs: 500}).then(() => {
  // Once training is complete, use the model to make predictions
  model.predict(tf.tensor2d([5], [1, 1])).print();  // Output will be close to 2*5 - 1 = 9
});

在这里,我们对模型进行 500 轮训练(训练数据的迭代)。训练后,我们使用模型来预测输入值为 5 的输出,该输出应返回接近 9 的值 (y = 2*5 - 1 = 9)。

3. 在浏览器中运行模型

要在浏览器中运行此模型,您需要一个包含 TensorFlow.js 库和 JavaScript 代码的 HTML 文件:



    
    
    TensorFlow.js Example
    
      


    

Simple Neural Network with TensorFlow.js

并且在您的 app.js 文件中,您可以包含上面的模型构建和训练代码。

版本声明 本文转载于:https://dev.to/pawandeore/getting-started-with-machine-learning-in-javascript-a-beginners-guide-with-tensorflowjs-2ol2?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • Python元类工作原理及类创建与定制
    Python元类工作原理及类创建与定制
    python中的metaclasses是什么? Metaclasses负责在Python中创建类对象。就像类创建实例一样,元类也创建类。他们提供了对类创建过程的控制层,允许自定义类行为和属性。在Python中理解类作为对象的概念,类是描述用于创建新实例或对象的蓝图的对象。这意味着类本身是使用类关...
    编程 发布于2025-04-27
  • 将图片浮动到底部右侧并环绕文字的技巧
    将图片浮动到底部右侧并环绕文字的技巧
    在Web设计中围绕在Web设计中,有时可以将图像浮动到页面右下角,从而使文本围绕它缠绕。这可以在有效地展示图像的同时创建一个吸引人的视觉效果。 css位置在右下角,使用css float and clear properties: img { 浮点:对; ...
    编程 发布于2025-04-27
  • Python中何时用"try"而非"if"检测变量值?
    Python中何时用"try"而非"if"检测变量值?
    使用“ try“ vs.” if”来测试python 在python中的变量值,在某些情况下,您可能需要在处理之前检查变量是否具有值。在使用“如果”或“ try”构建体之间决定。“ if” constructs result = function() 如果结果: 对于结果: ...
    编程 发布于2025-04-27
  • 如何处理PHP文件系统功能中的UTF-8文件名?
    如何处理PHP文件系统功能中的UTF-8文件名?
    在PHP的Filesystem functions中处理UTF-8 FileNames 在使用PHP的MKDIR函数中含有UTF-8字符的文件很多flusf-8字符时,您可能会在Windows Explorer中遇到comploreer grounder grounder grounder gro...
    编程 发布于2025-04-27
  • 如何在GO编译器中自定义编译优化?
    如何在GO编译器中自定义编译优化?
    在GO编译器中自定义编译优化 GO中的默认编译过程遵循特定的优化策略。 However, users may need to adjust these optimizations for specific requirements.Optimization Control in Go Compi...
    编程 发布于2025-04-27
  • 使用jQuery如何有效修改":after"伪元素的CSS属性?
    使用jQuery如何有效修改":after"伪元素的CSS属性?
    在jquery中了解伪元素的限制:访问“ selector 尝试修改“:”选择器的CSS属性时,您可能会遇到困难。 This is because pseudo-elements are not part of the DOM (Document Object Model) and are th...
    编程 发布于2025-04-27
  • 人脸检测失败原因及解决方案:Error -215
    人脸检测失败原因及解决方案:Error -215
    错误处理:解决“ error:( - 215)!empty()in Function openCv in Function MultSiscale中的“检测”中的错误:在功能检测中。”当Face Cascade分类器(即面部检测至关重要的组件)未正确加载时,通常会出现此错误。要解决此问题,必须...
    编程 发布于2025-04-27
  • 为什么PYTZ最初显示出意外的时区偏移?
    为什么PYTZ最初显示出意外的时区偏移?
    与pytz 最初从pytz获得特定的偏移。例如,亚洲/hong_kong最初显示一个七个小时37分钟的偏移: 差异源利用本地化将时区分配给日期,使用了适当的时区名称和偏移量。但是,直接使用DateTime构造器分配时区不允许进行正确的调整。 example pytz.timezone(...
    编程 发布于2025-04-27
  • CSS强类型语言解析
    CSS强类型语言解析
    您可以通过其强度或弱输入的方式对编程语言进行分类的方式之一。在这里,“键入”意味着是否在编译时已知变量。一个例子是一个场景,将整数(1)添加到包含整数(“ 1”)的字符串: result = 1 "1";包含整数的字符串可能是由带有许多运动部件的复杂逻辑套件无意间生成的。它也可以是故意从单个真理...
    编程 发布于2025-04-27
  • 在JavaScript中如何获取实际渲染的字体,当CSS字体属性未定义时?
    在JavaScript中如何获取实际渲染的字体,当CSS字体属性未定义时?
    Accessing Actual Rendered Font when Undefined in CSSWhen accessing the font properties of an element, the JavaScript object.style.fontFamily and objec...
    编程 发布于2025-04-27
  • 反射动态实现Go接口用于RPC方法探索
    反射动态实现Go接口用于RPC方法探索
    在GO 使用反射来实现定义RPC式方法的界面。例如,考虑一个接口,例如:键入myService接口{ 登录(用户名,密码字符串)(sessionId int,错误错误) helloworld(sessionid int)(hi String,错误错误) } 替代方案而不是依靠反射...
    编程 发布于2025-04-27
  • 如何在无序集合中为元组实现通用哈希功能?
    如何在无序集合中为元组实现通用哈希功能?
    在未订购的集合中的元素要纠正此问题,一种方法是手动为特定元组类型定义哈希函数,例如: template template template 。 struct std :: hash { size_t operator()(std :: tuple const&tuple)const {...
    编程 发布于2025-04-27
  • MySQL中如何高效地根据两个条件INSERT或UPDATE行?
    MySQL中如何高效地根据两个条件INSERT或UPDATE行?
    在两个条件下插入或更新或更新 solution:的答案在于mysql的插入中...在重复键更新语法上。如果不存在匹配行或更新现有行,则此功能强大的功能可以通过插入新行来进行有效的数据操作。如果违反了唯一的密钥约束。实现所需的行为,该表必须具有唯一的键定义(在这种情况下为'名称'...
    编程 发布于2025-04-27
  • 如何修复\“常规错误:2006 MySQL Server在插入数据时已经消失\”?
    如何修复\“常规错误:2006 MySQL Server在插入数据时已经消失\”?
    How to Resolve "General error: 2006 MySQL server has gone away" While Inserting RecordsIntroduction:Inserting data into a MySQL database can...
    编程 发布于2025-04-27
  • 在程序退出之前,我需要在C ++中明确删除堆的堆分配吗?
    在程序退出之前,我需要在C ++中明确删除堆的堆分配吗?
    在C中的显式删除 在C中的动态内存分配时,开发人员通常会想知道是否有必要在heap-procal extrable exit exit上进行手动调用“ delete”操作员,但开发人员通常会想知道是否需要手动调用“ delete”操作员。本文深入研究了这个主题。 在C主函数中,使用了动态分配变量(H...
    编程 发布于2025-04-27

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3