当前位置: 首页 > article >正文

从零开始:使用 Brain.js 创建你的第一个神经网络(一)

欢迎来到 brain.js 的学习之旅!

无论你是零基础的新手,还是已经有一定编程经验的开发者,这个系列都将为你提供一个系统、全面的学习路径。我们将从最基础的概念开始,逐步深入到实际应用和高级技巧,最终让你能够自信地构建和训练自己的神经网络模型。

以下是我们的学习路线图:

brainJS-roadmap

这一系列文章从入门到进阶,涵盖了 brain.js 的核心功能、技术细节以及实际应用场景。不仅适合初学者学习和实践,也为有一定基础的开发者提供了更多扩展和深入的思考方向。接下来,我们进入系列的第一部分:基础篇。

Brain.js-01

引言

神经网络是机器学习中的重要组成部分,而 brain.js 是一个易于使用的 JavaScript 库,可以帮助开发者快速搭建和训练神经网络模型。无论你是初学者还是已有一定经验的开发者,在本篇文章中,我们将专注于快速搭建一个简单的二分类模型。通过实际代码示例,你将掌握 brain.js 的基本用法并对神经网络的核心概念有初步理解。

一、什么是 brain.js

brain.js 是一个支持浏览器和 Node.js 环境的神经网络库,它的目标是简化神经网络的构建和训练过程。通过它,开发者无需深入理解复杂的数学公式和理论,只需编写少量代码即可完成神经网络的实现。

主要特点

  1. 简单易用:提供直观的 API,适合快速开发和学习。
  2. 跨平台支持:可以在浏览器和 Node.js 环境下运行。
  3. 支持多种任务:包括分类、回归、时间序列等多种任务类型。
  4. GPU 加速:支持 GPU 计算,显著提升训练速度。
  5. 扩展性强:可以与其他库或框架结合使用。

应用场景

  • 文本分类(如垃圾邮件检测)。
  • 时间序列预测(如股票价格预测)。
  • 图像处理(如手写数字识别)。
  • 推荐系统(如电影推荐)。

二、Brain.js 的发展历史和由来

brain.js 最早由 Heather Arthur 开发,并作为一个轻量级的 JavaScript 神经网络库发布。其核心目标是让开发者能够快速上手并体验神经网络的魅力,而无需深厚的数学基础或复杂的编程经验。

重要发展节点

  • 初版发布:在 GitHub 上推出后,因其易用性迅速受到关注。
  • GPU 加速支持:引入 gpu.js,显著提升模型训练和推理速度。
  • 现代化迁移:重构代码以支持 ES6+ 语法和模块化,适应现代 JavaScript 生态。

设计理念

brain.js 的设计理念是让每个开发者都能轻松地探索神经网络的可能性。它通过直观的 API 和简单的实现方式,让初学者无需复杂的理论知识也能快速构建模型。

当前现状

如今,brain.js 已支持多种任务类型(如分类、回归和时间序列预测),仍然是学习和实验神经网络的优秀工具。

三、什么是二分类模型?

二分类问题是机器学习中最常见的任务之一,指的是将数据点分类为两种类别中的一种。例如:

  • 判断一封邮件是垃圾邮件还是正常邮件。
  • 预测一个患者是否有某种疾病。

为了更好地理解二分类问题,我们将以经典的 XOR 问题 为例:
对于输入 [0, 0][0, 1][1, 0][1, 1],输出的目标分别是 0110。这是一个非线性分类问题,适合作为简单神经网络的入门案例。

四、项目初始化

在正式开始之前,我们需要创建并初始化一个 Node.js 项目。

4.1 创建项目目录

首先,创建一个新的项目目录并进入该目录:

mkdir brainjs-study-demo
cd brainjs-study-demo

4.2 初始化项目

使用 npm 初始化项目,生成 package.json 文件:

npm init -y

-y 参数会自动使用默认配置生成 package.json 文件。如果你想手动配置,可以去掉 -y 参数。

此时,项目目录中会生成一个 package.json 文件,记录了项目的基本信息和依赖项。

五、安装 brain.js

brain.js 是我们构建神经网络的核心库。

5.1 安装 brain.js

在项目目录中安装 brain.js:推荐 Node 版本为 v14.x

npm install brain.js

安装完成后, brain.js 会被添加到 package.jsondependencies 中。

5.2 安装 gpu.js(可选)

brain.js 依赖 gpu.js 来提升计算性能,但不会自动安装。如果你希望加速模型训练或者项目无法运行的情况,可以运行以下命令安装 gpu.js

npm install gpu.js

如果安装 gpu.js 失败,可能是因为缺少系统依赖。请根据系统环境安装必要的构建工具。

Windows 平台

  1. 安装 Python (建议使用 Python 3.x)。
  2. 安装 Visual Studio Build Tools,确保选择以下工作负载:
    • Node.js 开发工作负载
    • C++ 构建工具工作负载(如果需要)

六、编写第一个神经网络

6.1 创建 JavaScript 文件

在项目目录中创建一个新的 JavaScript 文件,例如 index.js

6.2 编写代码

打开 index.js 文件,添加以下代码:

// 引入 brain.js
const brain = require('brain.js');
// 创建神经网络
const net = new brain.NeuralNetwork();
// 定义训练数据(XOR 问题)
const trainingData = [
  { input: [0, 0], output: [0] },
  { input: [0, 1], output: [1] },
  { input: [1, 0], output: [1] },
  { input: [1, 1], output: [0] }
];
// 训练神经网络
net.train(trainingData);
// 测试神经网络
const output = net.run([1, 0]);  // 输入 [1, 0],期望输出接近 [1]
console.log(output);  // 输出类似 [0.9339389204978943]

6.3 参数解释

NeuralNetworkbrain.NeuralNetworkbrain.js 提供的核心类,用于创建前馈神经网络。默认情况下,网络结构为单隐藏层,节点数根据输入自动调整。

训练数据input 是输入特征,output 是期望结果。XOR 问题的输入和输出设计体现了二分类模型的目标。

七、训练数据的设计与优化

训练数据是神经网络学习的基础,其设计直接影响模型的表现。

7.1 数据格式

brain.js 中,训练数据由 inputoutput 组成:

  • input 是一个数组,表示输入特征。
  • output 是一个数组,表示期望输出。

例如:

{ input: [0, 1], output: [1] }

表示当输入 [0, 1] 时,期望输出为 [1]

7.2 数据归一化

为了提高训练效率,建议将输入数据归一化到 [0, 1] 范围。例如,若原始数据为 [0, 100],可以通过以下方式归一化:

const normalize = (value, max) => value / max;
const input = [normalize(50, 100), normalize(75, 100)];

八、保存和加载模型

为了避免每次运行代码都重新训练,可以将训练好的模型保存为 JSON 文件。

8.1 保存模型

在训练完成后,使用以下代码保存模型:

const fs = require('fs');
// 将模型保存为 JSON 文件
const model = net.toJSON();
fs.writeFileSync('model.json', JSON.stringify(model));

8.2 加载模型

const modelData = JSON.parse(fs.readFileSync('model.json'));
net.fromJSON(modelData);

九、扩展与优化

9.1 增加训练数据

扩展训练数据可以提高模型的准确性。例如:

const extendedTrainingData = [
  { input: [0, 0], output: [0] },
  { input: [0, 1], output: [1] },
  { input: [1, 0], output: [1] },
  { input: [1, 1], output: [0] },
  { input: [0.5, 0.5], output: [0] }
];
net.train(extendedTrainingData);

9.2 使用配置参数优化训练

brain.js 提供了多种训练参数:

  • iterations:神经网络训练的最大循环次数。
  • learningRate:控制参数更新的幅度,范围一般为 0.1-0.5。
  • errorThresh:允许的最大误差,默认值是 0.005(即 0.5% 的误差)。

例如:

net.train(trainingData, {
  iterations: 2000, // 训练迭代次数
  learningRate: 0.5, // 学习率
  errorThresh: 0.01 // 允许的最大误差
});

总结

通过本文,你学会了如何从零开始创建一个基于 brain.js 的神经网络,并了解了训练数据的设计与优化方法。这只是入门的第一步,未来的文章将深入探讨更多高级主题,例如 LSTM 网络、时间序列预测、模型调优等。

如果你在学习过程中有疑问,或者有自己的想法和建议,欢迎在评论区留言。大家一起讨论和交流!


http://www.kler.cn/a/512876.html

相关文章:

  • 2024年美赛C题评委文章及O奖论文解读 | AI工具如何影响数学建模?从评委和O奖论文出发-O奖论文做对了什么?
  • 学习ASP.NET Core的身份认证(基于JwtBearer的身份认证8)
  • Qt基础项目篇——Qt版Word字处理软件
  • 第12章:Python TDD完善货币加法运算(一)
  • Spring 中的事件驱动模型
  • LLMs(大型语言模型)的多智能体:Auto-GPT
  • Redis - 通用命令
  • Spring Boot 整合 PageHelper 实现分页功能
  • 线程池遇到未处理的异常会崩溃吗?
  • Redis的Windows版本安装以及可视化工具
  • PHP代码审计学习01
  • Github 2025-01-20 开源项目周报 Top15
  • Docker:基于自制openjdk8镜像 or 官方openjdk8镜像,制作tomcat镜像
  • Linux 时间操作详解
  • 什么是馈线自动化(FA)?其优点是什么?本文给出答案
  • 14,c++——继承
  • VSCode 使用默认profile打开文件
  • SpringBoot配置文件高级用法实战
  • RabbitMQ使用随笔
  • C语言勘破之路-最终篇 —— 预处理(上)
  • 高质量编程 性能优化学习笔记
  • redis-redission的加锁源码与看门狗机制
  • 【人工智能数学基础—微积分】深入详解梯度与梯度下降:掌握梯度下降法及其变种及模型参数的优化
  • 14天学习微服务-->第1天:微服务架构入门
  • Java锁 死锁及排查 JVM 工具 jconsole 工具 排查死锁
  • R语言的编程范式