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

深入探索Flax:一个用于构建神经网络的灵活和高效库

深入探索Flax:一个用于构建神经网络的灵活和高效库

在深度学习领域,TensorFlow 和 PyTorch 作为主流的框架,已被广泛使用。不过,Flax 作为一个较新的库,近年来得到了越来越多的关注。Flax 是一个由Google Research团队开发的高性能、灵活且可扩展的神经网络库。它建立在JAX上,提供了更强大的功能以及更高的灵活性。本文将深入介绍Flax库的基本概念,并通过实际代码展示如何使用它来构建神经网络模型。

1. Flax概述

Flax 是基于 JAX 库构建的。JAX是一个针对加速数值计算的库,支持自动求导,并且能够通过XLA(加速线性代数)优化硬件执行。Flax继承了JAX的计算优势,并通过简洁的API为用户提供了一个高效的方式来定义、训练和调试神经网络。

Flax的核心设计思想是灵活性。它允许用户对神经网络的每一部分进行高度自定义,同时还能享受高性能计算的优势。与TensorFlow或PyTorch相比,Flax的模块化程度较高,允许开发者完全控制模型的构建、训练、优化等方面。

2. Flax与JAX的关系

Flax的构建和工作方式深受JAX的影响。JAX本身是一个用于数值计算和自动微分的库,它利用了XLA加速器来提升计算效率。Flax通过JAX的自动微分和加速功能,提供了更加灵活的深度学习功能。

JAX的关键特性:

  • 自动求导:JAX提供了高效且灵活的自动求导功能,可以计算几乎任何Python代码的梯度。
  • XLA加速:JAX支持XLA优化,可以在多个硬件设备(如CPU、GPU和TPU)上加速计算。
  • 函数式编程:JAX的API高度依赖函数式编程风格,函数不可变性和透明计算是其核心特性之一。

Flax本身并不提供低级的优化和计算能力,而是依赖JAX来执行这些任务。因此,Flax能够利用JAX强大的功能,同时在此基础上提供神经网络构建的高层抽象。

3. Flax的核心组件

Flax的核心组件主要包括:

  • nn.Module:Flax中的每一个神经网络层都由Module定义,类似于PyTorch中的nn.Module。每个Module都可以包含网络的参数和前向计算逻辑。
  • optax:这是Flax常用的优化库,提供了多种优化算法,如Adam、SGD等。它与Flax紧密集成,帮助优化神经网络训练过程。
  • jax:Flax本身是建立在JAX之上的,因此,它可以利用JAX的自动微分、并行计算和加速功能。

4. Flax的特点与优势

Flax作为一个基于JAX的库,具有许多显著的优势:

1. 高灵活性

Flax允许用户完全控制模型的设计。你可以手动管理模型的参数和计算流程,灵活性非常高。尤其在需要实现自定义层、梯度计算或者网络架构时,Flax的功能非常适用。

2. 轻量化和模块化

Flax的API是高度模块化的,每个nn.Module都是一个独立的模块,你可以根据需要创建和组合不同的模块。这使得Flax非常适合研究性工作以及需要高度定制化的项目。

3. 自动微分与加速

Flax与JAX的紧密结合意味着你可以利用JAX的强大自动微分功能进行梯度计算。此外,JAX本身支持硬件加速,可以轻松在CPU、GPU和TPU上运行模型。

4. 简洁的API

Flax在提供强大功能的同时,其API设计简洁,易于理解。它特别适合希望快速实现和测试新算法的研究人员。

5. Flax实践:构建一个简单的神经网络

现在,我们来通过一个实际示例,展示如何使用Flax构建一个简单的神经网络模型。

安装依赖

首先,确保你已经安装了Flax和其他相关依赖:

pip install flax jax jaxlib optax

定义神经网络模型

Flax的神经网络模块是通过继承flax.linen.Module类来定义的。在Flax中,每个网络的构建都需要在apply方法中定义前向传播逻辑。以下是一个简单的多层感知机(MLP)模型:

import flax.linen as nn
import jax
import jax.numpy as jnpclass SimpleMLP(nn.Module):hidden_size: intoutput_size: intdef setup(self):# 定义网络层self.dense1 = nn.Dense(self.hidden_size)self.dense2 = nn.Dense(self.output_size)def __call__(self, x):# 前向传播:输入通过两层全连接层x = nn.relu(self.dense1(x))x = self.dense2(x)return x# 初始化模型
model = SimpleMLP(hidden_size=128, output_size=10)# 初始化输入数据
key = jax.random.PRNGKey(0)
x = jnp.ones((1, 28 * 28))  # 假设输入是28x28像素的图像# 初始化模型参数
params = model.init(key, x)
print(params)

训练模型

Flax本身并不直接处理训练过程,而是依赖于优化器来调整网络参数。我们可以使用optax库来定义和管理优化器。

import optax# 定义损失函数
def loss_fn(params, x, y):logits = model.apply(params, x)loss = jax.nn.softmax_cross_entropy(logits=logits, labels=y)return loss.mean()# 定义优化器
optimizer = optax.adam(learning_rate=1e-3)# 创建优化器状态
opt_state = optimizer.init(params)# 定义训练步骤
@jax.jit
def train_step(params, opt_state, x, y):grads = jax.grad(loss_fn)(params, x, y)  # 计算梯度updates, opt_state = optimizer.update(grads, opt_state)  # 更新参数params = optax.apply_updates(params, updates)  # 应用更新return params, opt_state# 假设有训练数据x_train, y_train
params, opt_state = train_step(params, opt_state, x, y)  # 训练一步

实战

继续深入Flax的实战部分,我们将构建一个完整的深度学习训练流程,包括数据加载、模型训练、验证和优化。我们将使用MNIST数据集进行演示,MNIST是一个常用于图像分类的标准数据集,包含手写数字图像。

1. 数据加载与预处理

在训练任何神经网络模型之前,首先需要加载并预处理数据。这里我们将使用tensorflow_datasets库来加载MNIST数据集,并将其转换为适合Flax使用的格式。

首先,安装tensorflow_datasets库:

pip install tensorflow-datasets

接下来,加载数据集并进行预处理:

import tensorflow_datasets as tfds
import jax.numpy as jnp
from flax.training import train_state
import optax# 加载MNIST数据集
def load_mnist_data():# 加载MNIST数据集并进行分割ds, info = tfds.load('mnist', as_supervised=True, with_info=True, split=['train[:80%]', 'train[80%:]'])train_ds, val_ds = ds# 转换为jax.numpy格式,并做批处理def preprocess(data):img, label = dataimg = jnp.array(img, dtype=jnp.float32) / 255.0  # 归一化处理img = img.flatten()  # 扁平化28x28图像为784维向量label = jnp.array(label, dtype=jnp.int32)return img, labeltrain_ds = train_ds.map(preprocess).batch(64)val_ds = val_ds.map(preprocess).batch(64)return train_ds, val_ds# 加载数据
train_ds, val_ds = load_mnist_data()

在这里,load_mnist_data函数加载了MNIST数据集并将其转换为Flax所需的格式,数据被归一化并转换为784维的向量以适应我们的神经网络输入。

2. 定义神经网络模型

我们接着定义一个简单的多层感知机(MLP)模型,网络的结构为两层隐藏层,每层包含128个神经元,并且使用ReLU激活函数。

class SimpleMLP(nn.Module):hidden_size: intoutput_size: intdef setup(self):self.dense1 = nn.Dense(self.hidden_size)self.dense2 = nn.Dense(self.output_size)def __call__(self, x):x = nn.relu(self.dense1(x))  # 第一层隐藏层x = self.dense2(x)  # 输出层return x

该模型由两个全连接层构成,nn.Dense是Flax中的标准全连接层。我们使用ReLU激活函数对第一层输出进行非线性转换,第二层输出是最终的分类结果。

3. 初始化模型与优化器

接下来,我们定义损失函数,初始化网络参数和优化器。我们将使用optax库中的Adam优化器。

# 定义损失函数
def loss_fn(params, x, y):logits = model.apply(params, x)loss = jax.nn.sparse_softmax_cross_entropy(logits=logits, labels=y)return loss.mean()# 创建模型
model = SimpleMLP(hidden_size=128, output_size=10)
key = jax.random.PRNGKey(0)
x_dummy = jnp.ones((1, 28 * 28))  # 假设输入图像是28x28的MNIST图像
params = model.init(key, x_dummy)# 定义优化器
optimizer = optax.adam(learning_rate=1e-3)
opt_state = optimizer.init(params)

这里我们使用jax.nn.sparse_softmax_cross_entropy来计算交叉熵损失函数,这是分类任务中常用的损失函数。Adam优化器被用来更新网络参数。

4. 训练步骤

Flax的训练过程通常使用jax.jit来加速计算。我们定义一个训练步骤,其中包括计算梯度、应用梯度更新模型参数。

@jax.jit
def train_step(params, opt_state, x, y):grads = jax.grad(loss_fn)(params, x, y)  # 计算梯度updates, opt_state = optimizer.update(grads, opt_state)  # 更新优化器状态params = optax.apply_updates(params, updates)  # 应用更新return params, opt_state# 训练循环
num_epochs = 10
for epoch in range(num_epochs):# 在训练数据上进行训练for batch in train_ds:x_batch, y_batch = batchparams, opt_state = train_step(params, opt_state, x_batch, y_batch)# 在验证集上计算损失val_loss = 0for batch in val_ds:x_batch, y_batch = batchval_loss += loss_fn(params, x_batch, y_batch)val_loss /= len(val_ds)print(f"Epoch {epoch + 1}, Validation Loss: {val_loss:.4f}")

在训练循环中,我们遍历训练数据集,并对每个批次的数据执行训练步骤。每个epoch结束时,我们计算验证集的损失。

5. 评估模型

为了评估模型的性能,我们可以使用accuracy来计算准确率。

# 计算准确率
def accuracy_fn(params, x, y):logits = model.apply(params, x)predicted_class = jnp.argmax(logits, axis=-1)return jnp.mean(predicted_class == y)# 计算在验证集上的准确率
val_accuracy = 0
for batch in val_ds:x_batch, y_batch = batchval_accuracy += accuracy_fn(params, x_batch, y_batch)
val_accuracy /= len(val_ds)print(f"Validation Accuracy: {val_accuracy:.4f}")

我们定义了一个简单的准确率函数,并在验证集上计算模型的准确率。

6. 总结

通过以上步骤,我们展示了如何使用Flax构建一个简单的神经网络模型,并实现数据加载、模型训练、验证和评估。Flax的灵活性和高性能使得它在深度学习研究和快速原型开发中非常有价值。

在实际应用中,你可以通过调整模型结构、优化器和训练超参数来进一步提高模型性能。此外,Flax还可以方便地与JAX的其他功能集成,如数据并行、分布式训练等,这为处理大规模深度学习任务提供了强大的支持。

随着Flax社区的不断发展,未来Flax将可能成为更多深度学习应用的首选库。

相关文章:

深入探索Flax:一个用于构建神经网络的灵活和高效库

深入探索Flax:一个用于构建神经网络的灵活和高效库 在深度学习领域,TensorFlow 和 PyTorch 作为主流的框架,已被广泛使用。不过,Flax 作为一个较新的库,近年来得到了越来越多的关注。Flax 是一个由Google Research团队…...

vue项目中单独文件的js不存在this.$store?.state怎么办

在Vue项目中,如果你在单独的文件(比如插件、工具函数等)中遇到this.$store不存在的情况,这通常是因为this上下文不指向Vue实例,或者Vuex store没有被正确地注入到Vue实例中。以下是几种可能的解决方案: 确保…...

物联网客户端在线服务中心(客服功能/私聊/群聊/下发指令等功能)

一、界面 私聊功能(下发通知类,一对多)群聊(点对点)发送指令(配合使用客户端,基于cefsharp做的物联网浏览器客户端)修改远程参数配置(直接保存到本地)&#…...

AI开发:逻辑回归 - 实战演练- 垃圾邮件的识别(二)

接上一篇AI开发:逻辑回归 - 实战演练- 垃圾邮件的识别(一) new_email 无论为什么文本,识别结果几乎都是垃圾邮件,因此我们需要对源码的逻辑进行梳理一下: 在代码中,new_email 无论赋值为何内容都被识别为…...

hint: Updates were rejected because the tip of your current branch is behind!

问题 本地仓库往远段仓库推代码时候提示: error: failed to push some refs to 192.168.2.1:java-base/java-cloud.git hint: Updates were rejected because the tip of your current branch is behind! refs/heads/master:refs/heads/master [rejected] (…...

Vue的数据驱动原理

文章目录 什么是数据驱动那么vuejs是如何实现这种数据驱动的呢?对getter/setter的理解?一个简单的演示例子vue数据驱动原理是:采用数据劫持结合发布者和订阅者模式,通过“object.defineproperty()”来劫持各个属性的setter、getter,在数据变动时发布消息给订阅者,触发相应…...

【Db First】.NET开源 ORM 框架 SqlSugar 系列

.NET开源 ORM 框架 SqlSugar 系列 【开篇】.NET开源 ORM 框架 SqlSugar 系列【入门必看】.NET开源 ORM 框架 SqlSugar 系列【实体配置】.NET开源 ORM 框架 SqlSugar 系列【Db First】.NET开源 ORM 框架 SqlSugar 系列【Code First】.NET开源 ORM 框架 SqlSugar 系列【数据事务…...

数据分析-52-时间序列分解之变分模态分解VMD

文章目录 1 时间序列模态分解1.1 模态分解的概念1.2 模态分解的作用1.3 常用的模态分解方法1.4 模态分解的常用库2 变分模态分解VMD2.1 VMD的流程2.2 加载数据集2.2.1 数据重采样2.2.2 原始数据可视化2.3 VMD变分模态分解3 参考附录1 时间序列模态分解 1.1 模态分解的概念 时…...

做异端中的异端 -- Emacs裸奔之路4: 你不需要IDE

确切地说,你不需要在IDE里面编写或者阅读代码。 IDE用于Render资源文件比较合适,但处理文本,并不划算。 这的文本文件,包括源代码,配置文件,文档等非二进制文件。 先说说IDE带的便利: 函数或者变量的自动…...

redhat 7.9配置阿里云yum源

1、mv /etc/yum.repos.d/*.repo /etc/yum.repos.d/backup/ 2、添加dns vim/etc/resolv.conf nameserver 8.8.8.8 nameserver 8.8.4.4 nameserver 114.114.114.114 #配置完先检查下通不通 3、vi /etc/yum/pluginconf.d/subscription-manager.conf # 将 “enabled1” 改为 “ena…...

简单快速的上手python

前言 python是一门可以快速上手的语言,原因是它语法简单,api容易使用自由灵活 当我们需要安装任何的三方库时,只需要执行 pip install XX 之后在代码里面import xxx就可以使用python啦。 并且python的代码自由灵活,使用缩进区…...

PHP和GD如何给图片添加模糊边缘效果

在PHP中,使用GD库给图片添加模糊边缘效果通常涉及几个步骤,包括加载图片、创建模糊效果、应用边缘处理以及保存结果图片。然而,GD库本身并不直接提供边缘模糊的函数,但你可以通过一些技巧来实现类似的效果。 以下是一个简化的步骤…...

PowerShell:查找并关闭打开的文件

Get-SmbOpenFile 打开 Windows PowerShell 并运行 Get-SmbOpenFile | Format-List 若要仅显示特定文件共享的连接,请使用 Where-Object 运行 Get-SmbOpenFile。 Get-SmbOpenFile | Where-Object Path -eq "C:\Data\" | Format-List Get-SmbSession 显…...

SQL进阶技巧:非等值连接--单向近距离匹配

目录 0 场景描述 1 数据准备 2 问题分析 ​编辑 ​编辑 3 小结 数字化建设通关指南 0 场景描述 表 t_1 和表 t_2 通过 a 和 b 关联时,有相等的取相等的值匹配,不相等时每一 个 a 的值在 b 中找差值最小的来匹。 表 t_1:a 中无重复值 表 t_1:a 中无重复值 a 1 2 4 …...

【golang】单元测试,以及出现undefined时的解决方案

单元测试 要对某一方法进行测试时,例如如下这一简单减法函数,选中函数名后右键->转到->测试 1)Empty test file 就是一个空文件,我们可以自己写测试的逻辑 但是直接点绿色箭头运行会出问题: 找不到包。我们要在…...

代理IP地址的含义与设置指南‌

在数字化时代,互联网已经成为我们日常生活不可或缺的一部分。然而,在享受互联网带来的便利的同时,我们也面临着隐私泄露、访问限制等问题。代理IP地址作为一种有效的网络工具,能够帮助我们解决这些问题。本文将详细介绍代理IP地址…...

Qt 2D绘图之三:绘制文字、路径、图像、复合模式

参考文章链接: Qt 2D绘图之三:绘制文字、路径、图像、复合模式 绘制文字 除了绘制图形以外,还可以使用QPainter::darwText()函数来绘制文字,也可以使用QPainter::setFont()设置文字所使用的字体,使用QPainter::fontInfo()函数可以获取字体的信息,它返回QFontInfo类对象…...

el-table 纵向 横向 多级表头

<el-table :data"tableData" class"diaTable":span-method"handleSpanMethod"border:header-cell-style"{background:#292929,color:#fff}"><!-- 纵向表头 --><el-table-column label"纵向表头" width"…...

linux perf安装问题解决

WARNING: perf not found for kernel 4.15.0-39 perf安装问题 perf是一个功能强大的linux性能分析工具&#xff0c;其功能依赖于内核&#xff0c;安装perf工具的版本必须与内核版本保持一致。 perf安装问题 使用apt 安装 perf包&#xff0c;运行时提示要安装与内核版本相一致…...

嵌入式Linux无窗口系统下搭建 Qt 开发环境

嵌入式Linux无窗口系统下搭建 Qt 开发环境 本文将介绍如何在树莓派的嵌入式 Linux 环境下&#xff0c;搭建 Qt 开发环境&#xff0c;实现无窗口系统模式&#xff08;framebuffer&#xff09;下的图形程序开发。 1. 安装 Qt 环境 接下来&#xff0c;安装核心 Qt 开发库以及与 …...

JSON vs 表单格式:两种常见请求格式的区别与应用

搞iOS UI 自动化的同时涉及到了给后端发送请求&#xff0c;请求数据的格式常用的有json格式和表单格式&#xff0c;这两种格式如何区分&#xff0c;如何使用&#xff0c;特此总结了一下。 表单格式&#xff08;Form Data&#xff09; 传统的 HTML 表单使用的请求体格式&#…...

通过torch.utils.data.DataLoader可提高深度学习的10倍运行的速度?

引言 在深度学习的训练过程中&#xff0c;数据加载是一个关键步骤&#xff0c;它直接影响到模型训练的效率。为了提高运行速度&#xff0c;我们通常会采用多种方法&#xff0c;比如数据预处理、多线程加载、缓存策略等。然而&#xff0c;有一个经常被忽视的优化点——调整torc…...

【QT】背景,安装和介绍

TOC 目录 背景 GUI技术 QT的安装 使用流程 QT程序介绍 main.cpp​编辑 Wiget.h Widget.cpp form file .pro文件 临时文件 C作为一门比较古老的语言&#xff0c;在人们的认知里始终是以底层&#xff0c;复杂和高性能著称&#xff0c;所以在很多高性能需求的场景之下…...

计算机网络:IP协议详细讲解

目录 前言 一、IP网段划分 二、IP报头 三、解决IP地址不足-->NAT技术 前言 在之前&#xff0c;我们学习了传输层中的TCP和UDP&#xff0c;重点是TCP协议&#xff0c;他帮我们解决具体到主机的哪个应用&#xff08;端口&#xff09;、传输的可靠&#xff08;序列号、校验和…...

Python中使用pip换源的详细指南

在Python开发过程中&#xff0c;我们经常需要安装各种第三方库。pip是Python的包管理工具&#xff0c;用于安装和管理Python库。然而&#xff0c;由于网络原因&#xff0c;有时访问默认的Python包索引&#xff08;PyPI&#xff09;可能会比较慢。这时&#xff0c;我们可以通过更…...

【Unity】WebGL全屏问题

1 前言 WebGL项目打包时不可避免的需要面对全屏化问题&#xff0c;或者说是占满网页的问题。这里讨论一下此问题。 2 全屏化 2.1 打包模板 WebGL在打包时可以选择不同的打包模板&#xff0c;其会影响最终打包好的项目在网页中的展现形式。可以在“Project Setting/Player/Set…...

基于大数据python 电商数据分析及推荐可视化系统(源码+LW+部署讲解+数据库+ppt)

&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 很对人不知道选题怎么选 不清楚自己适合做哪块内容 都可以免费来问我 避免后期給自己答辩找麻烦 增加难度&#xff08;部分学校只有一次答辩机会 没弄好就延迟…...

基于大数据python 热门微博数据分析可视化系统(源码+LW+部署讲解+数据库+ppt)

&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 很对人不知道选题怎么选 不清楚自己适合做哪块内容 都可以免费来问我 避免后期給自己答辩找麻烦 增加难度&#xff08;部分学校只有一次答辩机会 没弄好就延迟…...

MATLAB R2024b软件下载安装教程

软件版本: MATLAB R2024b 软件大小&#xff1a;24G 安装环境&#xff1a;Windows 10/11&#xff08;64位&#xff09; 界面语言&#xff1a;简体中文 软件下载&#xff1a;https://pan.xunlei.com/s/VOCut9-UJcX7k3AO7IGXobAiA1?pwdkqkr# 软件参考安装教程 1、使用网盘…...

机器学习算法(六)---逻辑回归

常见的十大机器学习算法&#xff1a; 机器学习算法&#xff08;一&#xff09;—决策树 机器学习算法&#xff08;二&#xff09;—支持向量机SVM 机器学习算法&#xff08;三&#xff09;—K近邻 机器学习算法&#xff08;四&#xff09;—集成算法 机器学习算法&#xff08;五…...

Pareidoscope - 语言结构关联工具

文章目录 关于 Pareidoscope安装使用方法输入格式语料库查询 将语料库转换为 SQLite3 数据库两种语言结构之间的关联简单词素分析关联共现和伴随词素分析相关的更大结构可视化关联结构 关于 Pareidoscope Pareidoscope 是一组 用于确定任意语言结构之间 关联的工具&#xff0c…...

Java中 HttpURLConnection 和 HttpClient 详解(初学者友好)

Java中HttpURLConnection和HttpClient详解&#xff08;初学者友好&#xff09; 在Java开发中&#xff0c;向服务器发送HTTP请求是常见的需求&#xff0c;比如调用API接口或获取远程数据。在JDK中&#xff0c;主要有两种方式实现HTTP通信&#xff1a; 使用 HttpURLConnection&…...

vulnhub-LUPINONE-靶场复盘-题解

靶机的下载连接https://download.vulnhub.com./empire/01-Empire-Lupin-One.zip 下载镜像后解压&#xff0c;然后导入到vmware中&#xff0c;使用的是nat模式 kali的ip地址&#xff1a;10.10.1.128 靶机ip地址&#xff1a;10.10.1.135 1.扫描靶机ip地址 命令&#xff1a;n…...

diff算法

vue的diff算法详解 vue&#xff1a; diff 算法是一种通过同层的树节点进行比较的高效算法 其有两个特点&#xff1a; 比较只会在同层级进行, 不会跨层级比较 在diff比较的过程中&#xff0c;循环从两边向中间比较 diff 算法在很多场景下都有应用&#xff0c;在 vue 中&…...

通过异步使用消息队列优化秒杀

通过异步使用消息队列优化秒杀 同步秒杀流程异步优化秒杀异步秒杀流程基于lua脚本保证Redis操作原子性代码实现阻塞队列的缺点 同步秒杀流程 public Result seckillVoucher(Long voucherId) throws InterruptedException {SeckillVoucher seckillVoucher iSeckillVoucherServi…...

项目整合logback日志打印线程id

项目打印日志能帮助我们解决很多的问题&#xff0c;提示我们出现的问题&#xff0c;通过日志我们可以准确的定位问题快速找到问题点解决问题。 <?xml version"1.0" encoding"UTF-8"?> <!-- 日志级别从低到高分为TRACE < DEBUG < INFO &l…...

WEB开发: 丢掉包袱,拥抱ASP.NET CORE!

今天的 Web 开发可以说进入了一个全新的时代&#xff0c;前后端分离、云原生、微服务等等一系列现代技术架构应运而生。在这个背景下&#xff0c;作为开发者&#xff0c;你一定希望找到一个高效、灵活、易于扩展且具有良好性能的框架。那么&#xff0c;ASP.NET Core 显然是一个…...

爬虫专栏第一篇:深入探索爬虫世界:基础原理、类型特点与规范要点全解析

本专栏会对爬虫进行从0开始的讲解&#xff0c;每一步都十分的细致&#xff0c;如果你感兴趣希望多多点赞收藏关注支持 简介&#xff1a;文章对爬虫展开多方面剖析。起始于爬虫的基本概念&#xff0c;即依特定规则在网络抓取信息的程序或脚本&#xff0c;在搜索引擎信息提取上作…...

SpringBoot3 + Vue3 由浅入深的交互 基础交互教学2

目录 一、这篇文章是基础交互教学系列的续作 二、发送请求时&#xff0c;携带发送的数据json格式的参数&#xff1a;data 三、携带token请求头&#xff0c;进行JWT校验 四、实现throw抛出异常&#xff0c;并交互显示在前端的界面 一、这篇文章是基础交互教学系列的续作 大…...

PID模糊控制算法(附MATLAB仿真程序)

一、基本原理 PID模糊控制算法是一种将传统PID控制与模糊逻辑相结合的控制策略。它利用模糊逻辑处理不确定性和非线性问题的能力&#xff0c;以提高控制系统的性能。以下是PID模糊控制算法的基本原理&#xff1a; 1.1. **误差和误差变化率的计算**&#xff1a; - 首先&…...

云轴科技ZStack助力 “上科大智慧校园信创云平台”入选上海市2024年优秀信创解决方案

近日&#xff0c;为激发创新活⼒&#xff0c;促进信创⾏业⾼质量发展&#xff0c;由上海市经济信息化委会同上海市委网信办、上海市密码管理局、上海市国资委等主办的“2024年上海市优秀信创解决方案”征集遴选活动圆满落幕。云轴科技ZStack支持的“上科大智慧校园信创云平台”…...

分布式集群下如何做到唯一序列号

优质博文&#xff1a;IT-BLOG-CN 分布式架构下&#xff0c;生成唯一序列号是设计系统常常会遇到的一个问题。例如&#xff0c;数据库使用分库分表的时候&#xff0c;当分成若干个sharding表后&#xff0c;如何能够快速拿到一个唯一序列号&#xff0c;是经常遇到的问题。实现思…...

Linux vi/vim

Linux vi/vim 所有的 Unix Like 系统都会内建 vi 文书编辑器&#xff0c;其他的文书编辑器则不一定会存在。 但是目前我们使用比较多的是 vim 编辑器。 vim 具有程序编辑的能力&#xff0c;可以主动的以字体颜色辨别语法的正确性&#xff0c;方便程序设计。 什么是 vim&…...

二分搜索(二)搜索插入位置

35. 搜索插入位置 给定一个排序数组和一个目标值&#xff0c;在数组中找到目标值&#xff0c;并返回其索引。如果目标值不存在于数组中&#xff0c;返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 示例 1: 输入: nums [1,3,5,6], target 5 输出: …...

postgresql in模糊查询

postgresql in模糊查询 plsql模糊查询表名 转载 一.简单查询 1.Select 列名,列名…from select e.empno,e.ename,e.job,e.sal from emp e(别名); 2.带条件查询 select 列名,列名,…,列名 from 表名 where –查询名字叫SMITH的员工的信息 select * from emp where ena…...

政府大数据面临的挑战

政府大数据在数据资源标准、共享、应用、评价以及数据资产转化方面面临着严峻挑战&#xff0c;因此需要从保障数据流动性的角度来重构信息体系&#xff0c;从关注流程和业务逻辑的角度转向关注数据流动性和数据价值&#xff0c;遵从信息流动的内在逻辑&#xff0c;发挥数据的最…...

数据结构---链表

1. 简介 链表&#xff08;Linked List&#xff09;是一种常见的线性数据结构&#xff0c;它由一系列节点组成&#xff0c;每个节点包含数据部分和指向下一个节点的指针&#xff08;或引用&#xff09;。链表的一个主要优点是能够高效地插入和删除元素&#xff0c;尤其是在数组…...

【系统架构设计师】真题论文: 论无服务器架构及其应用(包括解题思路和素材)

更多内容请见: 备考系统架构设计师-专栏介绍和目录 文章目录 真题题目(2017年 试题3)解题思路论文素材参考无服务器架构概念和特点无服务器架构的核心技术组件无服务器架构在不同领域的应用真题题目(2017年 试题3) 近年来,随着信息技术的迅猛发展和应用需求的快速更迭,…...

深度学习模型:BiLSTM (Bidirectional LSTM) - 双向长短时记忆网络详解

一、引言 在深度学习领域&#xff0c;序列数据的处理一直是一个关键任务。循环神经网络&#xff08;RNN&#xff09;及其变体在自然语言处理、语音识别、时间序列分析等诸多领域发挥着重要作用。然而&#xff0c;传统的 RNN 面临着梯度消失或梯度爆炸等问题&#xff0c;导致难…...

【计算机网络】实验3:集线器和交换器的区别及交换器的自学习算法

实验 3&#xff1a;集线器和交换器的区别及交换器的自学习算法 一、 实验目的 加深对集线器和交换器的区别的理解。 了解交换器的自学习算法。 二、 实验环境 • Cisco Packet Tracer 模拟器 三、 实验内容 1、熟悉集线器和交换器的区别 (1) 第一步&#xff1a;构建网络…...