Xavier 初始化:深度网络权重初始化的经典之作
Xavier 初始化:深度网络权重初始化的经典之作
发音:美 [zeɪvjər] n.泽维尔(男子名)
在深度学习的发展历程中,权重初始化对神经网络训练的成功至关重要。随机初始化的简单方法在浅层网络中尚可,但在深层网络中往往导致梯度消失或爆炸的问题。为了解决这一挑战,Xavier Glorot 和 Yoshua Bengio 在 2010 年提出了 Xavier 初始化(也称为 Glorot 初始化),一种基于输入和输出维度的优雅初始化策略。本文将深入探讨其原理、数学推导、PyTorch 实现以及适用场景,帮助你理解这一经典方法的魅力。
一、背景与动机
在深度神经网络中,信号(激活值)和梯度需要在多层之间稳定传播。如果权重初始化不当,可能出现以下问题:
- 梯度消失:激活值在前向传播中逐渐变小,反向传播中的梯度趋于零,网络停止学习。
- 梯度爆炸:激活值或梯度在前向传播或反向传播中指数增长,导致训练发散。
Xavier 初始化源于论文 Understanding the difficulty of training deep feedforward neural networks(Glorot & Bengio, 2010),旨在通过控制每一层输出的方差,确保信号在深层网络中的双向稳定性。它特别针对使用 Tanh 或 Sigmoid 等对称激活函数的网络设计,后来也被广泛应用于其他场景。
二、Xavier 初始化的数学原理
Xavier 初始化的核心思想是:保持每一层输入和输出的方差一致,同时在前向和反向传播中平衡信号传播。
1. 前向传播的方差分析
考虑一个线性层:
y = W x y = W x y=Wx
- ( x ∈ R n i n x \in \mathbb{R}^{n_{in}} x∈Rnin ):输入向量,( n i n n_{in} nin ) 是输入维度(也称 fan-in)。
- ( W ∈ R n o u t × n i n W \in \mathbb{R}^{n_{out} \times n_{in}} W∈Rnout×nin ):权重矩阵,( n o u t n_{out} nout ) 是输出维度(也称 fan-out)。
- ( y ∈ R n o u t y \in \mathbb{R}^{n_{out}} y∈Rnout ):输出向量。
假设:
- ( x x x ) 的每个元素是独立同分布(i.i.d.),方差为 ( Var ( x ) \text{Var}(x) Var(x) )。
- ( W W W ) 的每个元素也是 i.i.d.,初始方差为 ( Var ( W ) \text{Var}(W) Var(W) )。
输出 ( y i y_i yi ) 的方差为:
Var ( y i ) = Var ( ∑ j = 1 n i n W i j x j ) = ∑ j = 1 n i n Var ( W i j x j ) \text{Var}(y_i) = \text{Var}\left( \sum_{j=1}^{n_{in}} W_{ij} x_j \right) = \sum_{j=1}^{n_{in}} \text{Var}(W_{ij} x_j) Var(yi)=Var(j=1∑ninWijxj)=j=1∑ninVar(Wijxj)
若 ( W i j W_{ij} Wij ) 和 ( x j x_j xj ) 独立:
Var ( y i ) = n i n ⋅ Var ( W i j ) ⋅ Var ( x j ) = n i n ⋅ Var ( W ) ⋅ Var ( x ) \text{Var}(y_i) = n_{in} \cdot \text{Var}(W_{ij}) \cdot \text{Var}(x_j) = n_{in} \cdot \text{Var}(W) \cdot \text{Var}(x) Var(yi)=nin⋅Var(Wij)⋅Var(xj)=nin⋅Var(W)⋅Var(x)
为了保持 ( Var ( y ) = Var ( x ) \text{Var}(y) = \text{Var}(x) Var(y)=Var(x) ):
n i n ⋅ Var ( W ) = 1 ⟹ Var ( W ) = 1 n i n n_{in} \cdot \text{Var}(W) = 1 \implies \text{Var}(W) = \frac{1}{n_{in}} nin⋅Var(W)=1⟹Var(W)=nin1
2. 反向传播的方差分析
反向传播中,梯度从输出 ( y y y ) 传回输入 ( x x x ):
∂ L ∂ x = W T ⋅ ∂ L ∂ y \frac{\partial L}{\partial x} = W^T \cdot \frac{\partial L}{\partial y} ∂x∂L=WT⋅∂y∂L
- ( ∂ L ∂ y ∈ R n o u t \frac{\partial L}{\partial y} \in \mathbb{R}^{n_{out}} ∂y∂L∈Rnout):损失对输出的梯度。
- ( W T ∈ R n i n × n o u t W^T \in \mathbb{R}^{n_{in} \times n_{out}} WT∈Rnin×nout )。
梯度 ( ∂ L ∂ x j \frac{\partial L}{\partial x_j} ∂xj∂L) 的方差:
Var ( ∂ L ∂ x j ) = n o u t ⋅ Var ( W ) ⋅ Var ( ∂ L ∂ y ) \text{Var}\left(\frac{\partial L}{\partial x_j}\right) = n_{out} \cdot \text{Var}(W) \cdot \text{Var}\left(\frac{\partial L}{\partial y}\right) Var(∂xj∂L)=nout⋅Var(W)⋅Var(∂y∂L)
为了保持 ( Var ( ∂ L ∂ x ) = Var ( ∂ L ∂ y ) \text{Var}\left(\frac{\partial L}{\partial x}\right) = \text{Var}\left(\frac{\partial L}{\partial y}\right) Var(∂x∂L)=Var(∂y∂L)):
n o u t ⋅ Var ( W ) = 1 ⟹ Var ( W ) = 1 n o u t n_{out} \cdot \text{Var}(W) = 1 \implies \text{Var}(W) = \frac{1}{n_{out}} nout⋅Var(W)=1⟹Var(W)=nout1
3. 折中方案
前向传播要求 ( Var ( W ) = 1 n i n \text{Var}(W) = \frac{1}{n_{in}} Var(W)=nin1),反向传播要求 ( Var ( W ) = 1 n o u t \text{Var}(W) = \frac{1}{n_{out}} Var(W)=nout1)。Xavier 初始化取两者的调和平均:
Var ( W ) = 2 n i n + n o u t \text{Var}(W) = \frac{2}{n_{in} + n_{out}} Var(W)=nin+nout2
这平衡了信号在前向和反向传播中的稳定性。
4. 均匀分布的参数
Xavier 初始化使用均匀分布 ( U ( − a , a ) U(-a, a) U(−a,a) ):
Var ( W ) = ( a − ( − a ) ) 2 12 = ( 2 a ) 2 12 = a 2 3 \text{Var}(W) = \frac{(a - (-a))^2}{12} = \frac{(2a)^2}{12} = \frac{a^2}{3} Var(W)=12(a−(−a))2=12(2a)2=3a2
令:
a 2 3 = 2 n i n + n o u t \frac{a^2}{3} = \frac{2}{n_{in} + n_{out}} 3a2=nin+nout2
解得:
a = 6 n i n + n o u t a = \sqrt{\frac{6}{n_{in} + n_{out}}} a=nin+nout6
因此,权重初始化为:
W ∼ U ( − 6 n i n + n o u t , 6 n i n + n o u t ) W \sim U\left(-\sqrt{\frac{6}{n_{in} + n_{out}}}, \sqrt{\frac{6}{n_{in} + n_{out}}}\right) W∼U(−nin+nout6,nin+nout6)
三、PyTorch 中的实现
PyTorch 提供了 nn.init.xavier_uniform_
函数,签名如下:
torch.nn.init.xavier_uniform_(tensor, gain=1.0)
- tensor:要初始化的张量,通常是权重矩阵(形状为 ( [ n o u t , n i n ] [n_{out}, n_{in}] [nout,nin] ))。
- gain:增益因子,用于调整不同激活函数的幅度,默认值为 1.0(适用于 Tanh)。
- 对于 Sigmoid,推荐 ( g a i n = 1 gain = 1 gain=1 );
- 对于 ReLU,推荐 ( g a i n = 2 gain = \sqrt{2} gain=2 )(接近 Kaiming 初始化)。
实现逻辑:
fan_in, fan_out = tensor.shape[1], tensor.shape[0] # [n_out, n_in]
limit = gain * math.sqrt(6.0 / (fan_in + fan_out))
tensor.uniform_(-limit, limit)
四、使用场景与特点
1. 适用场景
- 激活函数:Xavier 初始化最初为 Tanh 和 Sigmoid 设计,因其对称性与方差分析匹配。
- 网络类型:适用于全连接网络(MLP)和早期卷积网络(CNN),在深度较浅或对称性强的模型中表现优异。
- 过渡性应用:在现代网络中(如 Transformer),常作为基线或与 ReLU 结合使用。
2. 优势
- 双向稳定性:同时考虑前向和反向传播,减少深层网络的训练困难。
- 简单易用:仅需输入和输出维度,无需复杂假设。
- 通用性:通过
gain
参数可适配不同激活函数。
3. 局限性
- ReLU 不完全匹配:Xavier 假设激活函数是对称的,而 ReLU 的非线性(截断负值)会导致方差减半,因此需要调整 ( gain )(如 ( 2 \sqrt{2} 2 ))。
- 现代网络复杂性:在 Transformer 或残差网络中,残差连接和归一化(如 LayerNorm)减轻了对初始化的依赖,Xavier 的优势被削弱。
- 数据依赖性:假设输入是 i.i.d.,对真实数据的非均匀分布可能不够鲁棒。
五、与 Kaiming 初始化的对比
Xavier 初始化和 Kaiming 初始化(He 初始化,可参考笔者的另一篇博客:Kaiming Uniform 初始化:神经网络权重初始化的优雅解决方案)是两种经典方法,区别如下:
- 目标激活函数:
- Xavier:Tanh、Sigmoid。
- Kaiming:ReLU 及其变体。
- 方差计算:
- Xavier:( Var ( W ) = 2 n i n + n o u t \text{Var}(W) = \frac{2}{n_{in} + n_{out}} Var(W)=nin+nout2),平衡输入输出。
- Kaiming:( Var ( W ) = 2 n i n \text{Var}(W) = \frac{2}{n_{in}} Var(W)=nin2),仅考虑输入(因 ReLU 减半效应)。
- 应用场景:
- Xavier:早期 MLP 和 CNN。
- Kaiming:现代深层网络(如 ResNet、Transformer)。
例如,在 LoRA 中,nn.init.kaiming_uniform_(..., a=math.sqrt(5))
实际上借鉴了 Xavier 的 ( a = 5 a = \sqrt{5} a=5 ) 传统,但更倾向于 Kaiming 的 ReLU 优化。
六、实践建议与改进方向
实践建议
- 选择 gain:根据激活函数调整 ( gain )(Tanh 用 1,ReLU 用 ( 2 \sqrt{2} 2 ))。
- 验证效果:在小型实验中比较 Xavier 和其他初始化(如 Kaiming)的收敛速度。
- 结合归一化:与 BatchNorm 或 LayerNorm 搭配使用,进一步稳定训练。
改进方向
- 动态 gain:根据网络深度或任务数据动态调整 ( gain )。
- 混合初始化:结合 Xavier 和 Kaiming 的优点,例如对称层用 Xavier,非对称层用 Kaiming。
- 正交扩展:在低秩场景(如 LoRA)中,尝试正交初始化替代均匀分布。
七、结语
Xavier 初始化作为深度学习早期的里程碑,通过数学推导解决了深层网络训练的稳定性问题。虽然在现代网络中,Kaiming 初始化因 ReLU 的流行而更常见,但 Xavier 依然是理解初始化原理的基石。无论你是初学者还是资深研究者,掌握 Xavier 都能为你的模型设计提供坚实基础。欢迎在评论区分享你的使用心得或疑问!
后记
2025年3月11日22点52分于上海,在Grok 3大模型辅助下完成。
相关文章:
Xavier 初始化:深度网络权重初始化的经典之作
Xavier 初始化:深度网络权重初始化的经典之作 发音:美 [zeɪvjər] n.泽维尔(男子名) 在深度学习的发展历程中,权重初始化对神经网络训练的成功至关重要。随机初始化的简单方法在浅层网络中尚可,但在深层…...
【量化策略】动量反转策略
【量化策略】动量反转策略 🚀量化软件开通 🚀量化实战教程 技术背景与应用场景 动量反转策略是一种基于市场行为分析的量化交易策略,它假设股票价格在经历一段时间的持续上涨或下跌后,会出现反转。这种策略适用于那些希望通过…...
菜鸟之路Day23一一JavaScript 入门
菜鸟之路Day23一一JavaScript 入门 作者:blue 时间:2025.3.10 文章目录 菜鸟之路Day23一一JavaScript 入门0.概述1.JS的引入方式2.JS的基础语法2.1输出语句2.2变量2.3数据类型2.4运算符2.5类型转换 3.函数4.JS对象4.1Array对象4.2String对象4.3Js自定义…...
FreeSWITCH 简单图形化界面40 - 使用mod_curl模块进行http请求
FreeSWITCH 简单图形化界面40 - 使用mod_curl模块进行http请求 0、界面预览00、简介1、编译安装1.1 编辑模块配置文件 2、使用2.1 拨号规则GET 请求POST 请求JSON 数据 2.2 Lua 脚本GET 请求POST 请求JSON 数据 3 、示例3.1 示例 1:提交 CDR 到第三方接口3.2 示例 2…...
TCP/IP原理详细解析
前言 TCP/IP是一种面向连接,可靠的传输,传输数据大小无限制的。通常情况下,系统与系统之间的http连接需要三次握手和四次挥手,这个执行过程会产生等待时间。这方面在日常开发时需要注意一下。 TCP/IP 是互联网的核心协议族&…...
HTTP与HTTPS的深度解析:技术差异、安全机制及应用场景
引言 HTTP(超文本传输协议)作为互联网通信的核心协议,自1991年诞生以来,经历了从HTTP/1.0到HTTP/3的多次迭代。然而,随着网络安全威胁的升级,纯HTTP协议因缺乏加密机制逐渐暴露其局限性。本文将重点解析HT…...
DrissionPage:更高效的动态爬虫实践(实例)
场景分析 代码重构对比 原Requests方案痛点 DrissionPage方案优势 重构后完整代码 关键技术点解析 1. 会话保持与指纹模拟 2. 智能请求重试 3. 反反爬策略 4. 混合模式扩展 性能对比测试 适用场景建议 常见问题解决 场景分析 原代码通过Requests直接调用B站API接…...
Triplet Loss原理及 Python实现
Triplet loss最初是谷歌在 FaceNet: A Unified Embedding for Face Recognition and Clustering 论文中提出的,可以学到较好的人脸的embedding Triplet Loss 是一种用于训练特征嵌入(feature embedding)的损失函数,广泛应用于人脸…...
2025人工智能AI新突破:PINN内嵌物理神经网络火了
最近在淘金的时候发现基于物理信息的神经网络(简称PINN)也是个研究热点,遂研读了几篇经典论文,深觉这也是个好发论文的方向,所以火速整理了一些个人认为很值得一读的PINN论文和同学们分享。 为了方面同学们更好地理解…...
深入探索Matter协议:开发Matter智能家居设备的基本步骤
随着家居智能化程度的提高,智能家居设备之间相互连接的网络虽然提升了家庭便利性,但也变得越来越复杂,难以管理。将亚马逊Alexa、Ring门铃、谷歌Nest Hub和苹果HomeKit等各种设备连接起来,并确保这些不同设备和操作系统能够良好地…...
搜广推校招面经四十五
快手主站推荐算法 这个是做因果选券的,如果大家的工作和这个有关,可以看看 一、有没有分析特征对各个的贡献度,怎么做? 传统的特征重要度衡量方法,就不介绍了。什么基于树模型的、SHAP值、LIME等。 但其实实际工程中…...
python之replace,strip,split命令
1. replace() 方法 功能:替换字符串中的指定子串 语法:str.replace(old, new[, count]) 特点: 全部替换(默认)或指定替换次数区分大小写返回新字符串,原字符串不变 示例: text "Hello…...
C语言处理字符串的十个函数(附带大量实例)
C语言的字符串处理函数主要集中在 <string.h> 头文件中,使用这些函数前必须包含该头文件。 字符串处理函数操作的对象通常是字符串(以 \0 结尾的字符数组),它们极大地方便了文本处理任务。 以下是我们将要讲解的主要函数&…...
【10】单片机编程核心技巧:指令周期与晶振频率
【10】单片机编程核心技巧:指令周期与晶振频率 🌟 核心概念 单片机的运算速度与时间控制,本质上由 指令周期 和 晶振频率 共同决定。理解这两者的关系,是掌握单片机底层控制的关键。 📌 1. 节拍与指令周期 …...
GitLab的Dockerfile 追踪
为了在 GitLab 上准备每个平台的 Docker 镜像文件,并实现完整的 Dockerfile 追踪,可以按照以下步骤进行操作: 项目准备 首先,确保你有一个 GitLab 项目,并且本地已经克隆了该项目的仓库。如果还没有项目,可…...
HTML基础
前言 什么是 HTML? HTML 是一种用于创建网页结构的标记语言,通过标签(Tag)定义内容的结构和呈现方式。 浏览器解析 HTML 文档后,将其渲染为可视化网页。 一、HTML 语法 1. HTML 基本骨架 所有 HTML 文档必须包含以下…...
静态时序分析:无法满足的生成时钟(TIM-255警告、UITE-461或PTE-075错误)
相关阅读 静态时序分析https://blog.csdn.net/weixin_45791458/category_12567571.html?spm1001.2014.3001.5482 在阅读本文前,强烈建议首先阅读介绍生成时钟的文章,尤其是其中关于时钟极性和反相的相关内容。 静态时序分析:SDC约束命令cr…...
SpringBoot日常:集成shareingsphere-jdbc
文章目录 pom依赖application.yml配置log4j2.xml实体类MapperServicecontroller调用插入接口调用查询接口 本章内容我们来聊聊如何将shareingsphere-jdbc集成到我们自己的springboot项目中,本章采用的shareingsphere-jdbc版本是5.1.2,springboot项目是2.…...
Java 生成图形验证码
一、图形验证码的意义 图形验证码是一种广泛应用于互联网领域的安全验证机制,它通过向用户展示包含字符、数字、图形等信息的图片,要求用户正确识别并输入其中的内容,以此来区分用户是人类还是机器程序。图形验证码具有多方面重要意义&#…...
nextjs15简要介绍以及配置eslint和prettier
目录 一、Next.js 何时使用服务器端渲染(SSR)?何时使用静态生成(SSG)? 1、服务器端渲染(SSR - getServerSideProps) 2、 静态生成(SSG - getStaticProps) …...
插入排序算法优化
一 插入排序概述 插入排序是稳定的原地排序算法,核心思想是逐步构建有序序列。对于未排序部分的每个元素,在已排序序列中从后向前扫描,找到合适位置插入。时间复杂度为: 最优:O(n)(已有序) 最差:O(n^2)(完全逆序) 平均:O(n^2) 二 二分查找优化(减少比较次数)…...
python学智能算法(七)|KNN邻近算法
【1】引言 前述学习进程中,已经了解了一些非常经典的智能算法,相关文章包括且不限于: python学智能算法(三)|模拟退火算法:深层分析_模拟退火 动画演示-CSDN博客 python学智能算法(四&#x…...
LabVIEW闭环控制系统硬件选型与实时性能
在LabVIEW闭环控制系统的开发中,硬件选型直接影响系统的实时性、精度与稳定性。需综合考虑数据采集速度(采样率、接口带宽)、计算延迟(算法复杂度、处理器性能)、输出响应时间(执行器延迟、控制周期&#x…...
JavaScript(Web APIs)
这个阶段两天也能看完 目录 壹_DOM-获取元素 00、获取DOM元素(根据CS选择器来获取DOM元素) 01、修改元素内容 02、修改CSS 03、H5自定义属性 04、定时器 贰_DOM-事件基础 00、事件监听 01、事件类型 02、事件对象 03、环境对象 04、回调函数 叁_DOM-事…...
创建Electron35 + vue3 + electron-builder项目,有很过坑,记录过程
环境: node v20.18.0 npm 11.1.0 用到的所有依赖: "dependencies": {"core-js": "^3.8.3","vue": "^3.2.13","vue-router": "^4.5.0"},"devDependencies": {"ba…...
机器视觉条形光源应用解析
在机器视觉中,条形光源是一种常见的照明设备,通过其特殊的形状和光路设计,能够有效解决检测中的光照均匀性、反光抑制、对比度增强等问题。以下是关于条形光源的详细解析: 1. 条形光源的基本结构与类型 结构:由多个LED灯珠沿直线或弧形排列,通常封装在长条形外壳中,可单…...
苹果商店上架流程,app上架发布流程
苹果商店地址 https://appstoreconnect.apple.com/login 其他地址:开发 - Apple Developer 1.更新代码 将项目的代码更新到最新,更新成功后右下角会给出提示 2.打开模拟器 鼠标右键可以选择设备(Device) 3.测试运行 如下图可以看到已经识别到设备了,点击运行即可,运行到模…...
大数据技术在土地利用规划中的应用分析
大数据技术在土地利用规划中的应用分析 一、引言 土地利用规划是对一定区域内的土地开发、利用、整治和保护所作出的统筹安排与战略部署,对于实现土地资源的优化配置、保障社会经济的可持续发展具有关键意义。在当今数字化时代,大数据技术凭借其海量数据处理、高效信息挖掘等…...
【Axure资料】110套优质可视化大屏模板+图表组件+科技感元件等
本作品集包含110套高保真可视化大屏模板,以及丰富的图表组件和科技感元件,旨在满足各行业对数据可视化展示的需求。所有模板和组件均基于Axure RP 9软件设计,确保高质量的交互体验和视觉效果。 作品类型:Axure原型模板 兼容版本&…...
TCP-IP协议通信模型
一、TCP/IP协议概述 TCP/IP协议即传输控制协议/互联网协议,也被称为网络通讯协议。它包含了一系列构成互联网基础的网络协议,是Internet的核心协议。 二、TCP/IP协议通信模型 文件中提到了TCP/IP协议通信模型,但未详细展开其具体层次结构和…...
VMware下载安装Ubuntu详解
一、Linux简介 1、不同领域的主流操作系统 桌面操作系统服务器操作系统移动设备操作系统嵌入式操作系统 1.1、桌面操作系统 Windows(用户数量最多)Mac OS(苹果电脑操作系统)Linux(用户数量少) 1.2、服…...
wpf label 内容绑定界面不显示
<Label Content"{Binding LabelText}" /> ... public string LabelText {get;set;}后端改变值后,界面内容并不显示 查看资料后改动如下 private string _labelText; public string LabelText{get { return _labelText; }set { _labelText value; OnPropertyCh…...
VC++ 获取目的IP的路由
GetBestRoute 函数获取到目的IP的最佳匹配路由。 第一个参数为:destination(目的IP) 第二个参数为:source(源IP) 通常不需要指定第二个source,这个一般用来匹配具体某一个网卡接口路由的&…...
海外跨境专线是什么?如何搭建海外跨境专线?
网络跨境专线——这一名词你听说过吗?如果你在跨境经济、国际贸易或网络通信领域工作,那它一定是你日常工作的一个重要话题。今天我们就来聊聊网络跨境专线的概念和搭建方法,希望能够为你在这一领域的探索提供一些帮助。 一、什么是网络跨境…...
【神经网络】python实现神经网络(二)——正向推理的模拟演练
一.神经网络假设 在开始讲解之前,首先我们假设有这样一套神经网络,一共有三层: 其中,关于神经网络的权重、偏置的符号定义如下(如果不知道什么是权重和偏置,可以参考我之前写过的一篇文章:【机器学习】机器学习是什么意思): 以下文章将沿用以上这个设…...
【从零开始学习计算机科学】操作系统(八)IO管理
【从零开始学习计算机科学】操作系统(八)IO管理 IO管理IO设备IO设备的分类IO控制器设备控制器的IO端口编址设备数据传输控制方法缓冲技术缓冲区的分类常用的缓冲技术虚拟设备IO设备的分配IO相关的软件的设计IO管理 IO设备 IO设备就是可以将数据输入到计算机,或者可以接收计…...
MySQL的安装及配置
一.以安装包方式下载 1.进入MySQL官网,下载安装包 官网链接:https://downloads.mysql.com/archives/installer/ 2.安装MySQL 二.压缩包方式下载 下载位置:mysql下载位置 解压缩后位置:D:\mysql-8.0.15-winx64 在主目录下复制…...
macOS 终端优化
macOS 安装、优化、还原、升级 Oh My Zsh 完全指南 🚀 Oh My Zsh 是 macOS 终端增强的利器,它能提供强大的自动补全、主题定制和插件支持,让你的终端更高效、更炫酷。本文将全面介绍 如何安装、优化、还原、重新安装和升级 Oh My Zsh&#x…...
Java三种注释方式
Java有三种注释:单行注释(//,从//到行尾被忽略,用于简单说明),多行注释(/* */,可包含多行内容,用于解释逻辑或禁用代码),文档注释(/**…...
Java 无 GUI 浏览器:HtmlUnit 入门及实战 [特殊字符]
文章目录 HtmlUnit 入门功能简介入门案例更多功能HtmlUnit 实战需求页面分析编码参考⭐ 本文目标: HtmlUnit 框架入门HtmlUnit 框架实战:实现 HtmlUnit 访问 Web 页面,并实现 Web 页面按钮点击,同时获取到下载的文件。HtmlUnit 入门 🚀 官网:https://htmlunit.sourcefo…...
前端如何发布npm包
1. 初始化项目 确保你的项目已经初始化,并生成 package.json 文件。如果没有,运行以下命令: npm init -y 按照提示填写项目信息(如项目名称、版本、描述等),生成 package.json 文件。 2. 安装 Webpack 在项目目录下安装 Webpack 及其相关工具: npm install webpack…...
光谱相机检测肉类新鲜度的原理
光谱相机通过分析肉类样本在特定波长范围内的光谱反射特性,结合化学与生物指标的变化规律,实现对其新鲜度的无损检测。其核心原理可概括为以下方面: 一、光谱特征与物质成分的关联性 物质特异性吸收/反射 不同化学成分(如水分…...
【计算机网络】深入解析 HTTP 请求中的 header 类型:Cookie 的概念、特点和应用场景:登录和用户认证
网络原理— HTTP 请求“报头”(header) Cookie 是什么 HTTP报头中的Cookie,用大白话来说,就像你去餐厅吃饭时拿到的一张会员卡: 初次访问 (清除该网站的所有 Cookie 后重新访问该网站,效果相同): 当你第一次访问一个网…...
红队OPSEC(安全运营)个人总结
OPSEC又称:运营安全,是指在红队的视角下,蓝队对我方的威胁。 OPSEC漏洞的五个流程: 关键信息识别:指红队的关键信息不泄露,包括但不限于红队的攻击意图,能力,人员,活动及…...
《Python基础教程》附录B笔记:Python参考手册
《Python基础教程》第1章笔记👉https://blog.csdn.net/holeer/article/details/143052930 附录B Python参考手册 Python标准文档是完整的参考手册。本附录只是一个便利的速查表,当你开始使用Python进行编程后,它可帮助你唤醒记忆。 B.1 表…...
GWO-CNN-BiLSTM-Attention多变量多步时间序列预测 | Matlab实现灰狼算法优化卷积双向长短期记忆融合注意力机制
GWO-CNN-BiLSTM-Attention多变量多步时间序列预测 | Matlab实现灰狼算法优化卷积双向长短期记忆融合注意力机制 目录 GWO-CNN-BiLSTM-Attention多变量多步时间序列预测 | Matlab实现灰狼算法优化卷积双向长短期记忆融合注意力机制预测效果基本介绍程序设计参考资料 预测效果 基…...
Python实例:PyMuPDF实现PDF翻译,英文翻译为中文,并按段落创建中文PDF
基于PyMuPDF与百度翻译的PDF翻译处理系统开发:中文乱码解决方案与自动化排版实践 一 、功能预览:将英文翻译为中文后创建的PDF 二、完整代码 from reportlab.lib.pagesizes import letter from reportlab.lib.styles import getSampleStyleSheet, ParagraphStyle...
【数据结构】初识集合框架及背后的数据结构(简单了解)
目录 前言 如何学好数据结构 1. 什么是集合框架 2. 集合框架的重要性 3. 背后所涉及的数据结构以及算法 3.1 什么是数据结构 3.2 容器背后对应的数据结构 3.3 相关java知识 3.4 什么是算法 3.5 基本关系说明(重要,简单了解) 前言 …...
Go语言集成DeepSeek API和GoFly框架文本编辑器实现流式输出和对话(GoFly快速开发框架)
说明 本文是GoFly快速开发框架集成Go语言调用 DeepSeek API 插件,实现流式输出和对话功能。为了方便实现更多业务功能我们在Go服务端调用AI即DeepSeek接口,处理好业务后再用Gin框架实现流失流式输出到前端,前端使用fetch请求接收到流式的mar…...
ClickHouse 数据倾斜实战:案例分析与优化技巧
目录 ClickHouse 数据倾斜问题总结与优化措施 1. 分片键选得不好,埋下隐患 2. 数据本身就“偏心” 3. 查询习惯加剧失衡 4. 硬件差异“雪上加霜” 表现形式一览 优化措施:从根源到实践 优化分片键:让数据均匀“落户” 数据预处理:写入前先“理顺” 查询优化:别让…...