FPGA实现Aurora 64B66B数据回环传输,基于GTX高速收发器,提供2套工程源码和技术支持

目录

  • 1、前言
    • Aurora 64B66B是啥?
    • 官方有Example,为何要用你这个?
    • 工程概述
    • 免责声明
  • 2、相关方案推荐
    • 我已有的所有工程源码总目录----方便你快速找到自己喜欢的项目
    • 我这里已有的 GT 高速接口解决方案
    • 本方案在Aurora 8B10B上的应用
  • 3、工程详细设计方案
    • 工程设计原理框图
    • 用户数据发送模块
    • Aurora 64B66B数据回环传输架构
      • Aurora 64B66B IP核简介
      • Aurora 64B66B 基本结构
      • Aurora 64B66B 发送流程
      • Aurora 64B66B 接收流程
      • Aurora 64B66B 时钟架构
      • Aurora 64B66B IP核调用和使用
    • 用户数据接收模块
    • 工程源码架构
    • 工程仿真
  • 4、vivado工程源码1详解-->Kintex7-325T版本
  • 5、vivado工程源码2详解-->Zynq7100版本
  • 6、工程移植说明
    • vivado版本不一致处理
    • FPGA型号不一致处理
    • 其他注意事项
  • 7、上板调试验证
    • 准备工作
    • Aurora 64B66B光口数据回环效果演示
  • 8、工程代码的获取

FPGA实现Aurora 64B66B数据回环传输,基于GTX高速收发器,提供2套工程源码和技术支持

1、前言

Aurora 64B66B是啥?

Aurora 64B/66B 是Xilinx(现AMD)开发的高性能链路层协议,专为超高带宽串行通信设计。它采用64B/66B编码方案,提供比传统8B/10B更高的有效带宽利用率(97% vs 80%),主要应用于数据中心、5G基础设施等需要100Gbps+传输的场景
Aurora 64B66B核心作用如下:
1、超高带宽传输:支持25Gbps至112Gbps线速率
2、低协议开销:仅3.125%的编码开销(对比8B/10B的25%)
3、多通道聚合:支持多达32通道绑定
4、前向纠错:集成Reed-Solomon FEC增强可靠性
5、灵活拓扑:支持点对点、环网和星型结构

Aurora 64B66B主要工程应用如下:
在这里插入图片描述
博主之前实现过Aurora 8B10B编解码,本博客用的则是Aurora 64B66B IP核,这两种方法编解码器区别如下:
Aurora 64B/66B vs 8B/10B 全面对比
在这里插入图片描述
在这里插入图片描述

官方有Example,为何要用你这个?

Xilinx官方的确有Aurora 64B66B IP核的Example例程;
然后呢?你看得懂吗?你会照着模仿做自己的项目吗?
如果你会,那么请划走;
如果你不会,不妨看看下面的聊天记录
在这里插入图片描述
这位朋友用了我的Aurora 64B66B数据回环传输工程,感觉少走了一年的弯路。。。

工程概述

本设计使用Xilinx 7系列FPGA为平台,基于GTX高速收发器实现Aurora 64B66B数据回环传输,旨在为读者提供一套精简版的、基于Aurora 64B66B编解码的数据收发架构;

FPGA内部设计了一个纯verilog代码实现的用户数据发送模块,该模块生成发送AXI4-Stream流接口的数据帧,数据帧的数据位宽、数据长度、每帧发送间隔、累加数据初始值、是否启用ILA数据观测等都可由parameter参数配置,数据帧以累加数形式出现,方便用户仿真和ILA观测,数据帧虽简单,但完美适配了Aurora 64B66B IP核的用户发送接口,是基于Aurora 64B66B传输其他数据的基础范本,可加速用户产品开发周期;用户数据发送数据然后送入Xilinx官方的Aurora 64B66B IP核实现64B66B数据编码,然后数据以高速差分信号输出,经板载的SFP光口进行回环传输;经SFP-RX接口输入高速差分信号再进入Xilinx官方的Aurora 64B66B IP核实现64B66B数据解码,然后输出AXI4-Stream数据流;接收AXI4-Stream流然后进入纯verilog代码实现的用户数据接收比对模块,实现接收数据与发送数据的逐个比较;最后将比较结果输出功设计者分析判断;整个工程实用性拉满,对于有Aurora 64B66B开发需求的用户可谓精准适配;针对市场主流需求,本博客设计并提供2套工程源码,具体如下:
在这里插入图片描述
现对上述2套工程源码做如下解释,方便读者理解:

工程源码1

开发板FPGA型号为Xilinx–>Kintex7–35T–xc7k325tffg676-2;FPGA内部设计了一个纯verilog代码实现的用户数据发送模块,该模块生成发送AXI4-Stream流接口的数据帧,数据帧的数据位宽、数据长度、每帧发送间隔、累加数据初始值、是否启用ILA数据观测等都可由parameter参数配置,数据帧以累加数形式出现,方便用户仿真和ILA观测,数据帧虽简单,但完美适配了Aurora 64B66B IP核的用户发送接口,是基于Aurora 64B66B传输其他数据的基础范本,可加速用户产品开发周期;用户数据发送数据然后送入Xilinx官方的Aurora 64B66B IP核实现64B66B数据编码,然后数据以高速差分信号输出,经板载的SFP光口进行回环传输;经SFP-RX接口输入高速差分信号再进入Xilinx官方的Aurora 64B66B IP核实现64B66B数据解码,然后输出AXI4-Stream数据流;接收AXI4-Stream流然后进入纯verilog代码实现的用户数据接收比对模块,实现接收数据与发送数据的逐个比较;最后将比较结果输出功设计者分析判断;整个工程实用性拉满,对于有Aurora 64B66B开发需求的用户可谓精准适配;本设计只使用到1路GTX高速收发器资源,对应的只使用板载 的1路SFP光口做回环,Aurora 64B66B用户数据位宽为64 bit;

工程源码2

开发板FPGA型号为Xilinx–>Zynq7100–xc7z100ffg900-2;FPGA内部设计了一个纯verilog代码实现的用户数据发送模块,该模块生成发送AXI4-Stream流接口的数据帧,数据帧的数据位宽、数据长度、每帧发送间隔、累加数据初始值、是否启用ILA数据观测等都可由parameter参数配置,数据帧以累加数形式出现,方便用户仿真和ILA观测,数据帧虽简单,但完美适配了Aurora 64B66B IP核的用户发送接口,是基于Aurora 64B66B传输其他数据的基础范本,可加速用户产品开发周期;用户数据发送数据然后送入Xilinx官方的Aurora 64B66B IP核实现64B66B数据编码,然后数据以高速差分信号输出,经板载的SFP光口进行回环传输;经SFP-RX接口输入高速差分信号再进入Xilinx官方的Aurora 64B66B IP核实现64B66B数据解码,然后输出AXI4-Stream数据流;接收AXI4-Stream流然后进入纯verilog代码实现的用户数据接收比对模块,实现接收数据与发送数据的逐个比较;最后将比较结果输出功设计者分析判断;整个工程实用性拉满,对于有Aurora 64B66B开发需求的用户可谓精准适配;本设计只使用到1路GTX高速收发器资源,对应的只使用板载 的1路SFP光口做回环,Aurora 64B66B用户数据位宽为64 bit;

本博客详细描述了FPGA实现Aurora 64B66B数据回环传输的设计方案,工程代码可综合编译上板调试,可直接项目移植,适用于在校学生、研究生项目开发,也适用于在职工程师做学习提升,可应用于医疗、军工等行业的高速接口或图像处理领域;
提供完整的、跑通的工程源码和技术支持;
工程源码和技术支持的获取方式放在了文章末尾,请耐心看到最后;

免责声明

本工程及其源码即有自己写的一部分,也有网络公开渠道获取的一部分(包括CSDN、Xilinx官网、Altera官网等等),若大佬们觉得有所冒犯,请私信批评教育;基于此,本工程及其源码仅限于读者或粉丝个人学习和研究,禁止用于商业用途,若由于读者或粉丝自身原因用于商业用途所导致的法律问题,与本博客及博主无关,请谨慎使用。。。

2、相关方案推荐

我已有的所有工程源码总目录----方便你快速找到自己喜欢的项目

其实一直有朋友反馈,说我的博客文章太多了,乱花渐欲迷人,自己看得一头雾水,不方便快速定位找到自己想要的项目,所以本博文置顶,列出我目前已有的所有项目,并给出总目录,每个项目的文章链接,当然,本博文实时更新。。。以下是博客地址:
点击直接前往

我这里已有的 GT 高速接口解决方案

我的主页有FPGA GT 高速接口专栏,该专栏有 GTP 、 GTX 、 GTH 、 GTY 等GT 资源的视频传输例程和PCIE传输例程,其中 GTP基于A7系列FPGA开发板搭建,GTX基于K7或者ZYNQ系列FPGA开发板搭建,GTH基于KU或者V7系列FPGA开发板搭建,GTY基于KU+系列FPGA开发板搭建;以下是专栏地址:
点击直接前往

本方案在Aurora 8B10B上的应用

本方案在Aurora 8B10B上也有应用应用,可以参考我之前发布的博客,链接如下:
点击直接前往

3、工程详细设计方案

工程设计原理框图

工程设计原理框图如下:
在这里插入图片描述

用户数据发送模块

用户数据发送模块在工程中位置如下:
在这里插入图片描述
FPGA内部设计了一个纯verilog代码实现的用户数据发送模块,该模块生成发送AXI4-Stream流接口的数据帧,数据帧的数据位宽、数据长度、每帧发送间隔、累加数据初始值、是否启用ILA数据观测等都可由parameter参数配置,数据帧以累加数形式出现,方便用户仿真和ILA观测,数据帧虽简单,但完美适配了Aurora 64B66B IP核的用户发送接口,是基于Aurora 64B66B传输其他数据的基础范本,可加速用户产品开发周期;用户数据发送模块顶层接口如下:
在这里插入图片描述

Aurora 64B66B数据回环传输架构

本设计基于GTX高速收发器实现Aurora 64B66B数据回环传输,总体代码架构如下:
在这里插入图片描述
Aurora 8B10B数据回环传输架构的核心是Aurora 8B10B IP核的例化和使用,所以本章节我们重点讲解这个IP;

Aurora 64B66B IP核简介

关于Aurora 64B66B IP核介绍最详细的肯定是Xilinx官方的《pg074_Aurora 64B/66B LogiCORE IP Product Guide》,我们以此来解读,《pg074》PDF文档我已放在了资料包里;我用到的开发板FPGA型号为Xilinx–7系列FPGA;带有多路GTX资源,每通道的收发速度为500 Mb/s到10.3125 Gb/s之间(GTX为例)。本设计使用的Aurora 64B66B IP核基于GTX高速收发器实现物理层和数据链路层;

Aurora 64B66B 基本结构

根据《pg074_Aurora 64B/66B LogiCORE IP Product Guide》,Aurora 64B66B基本结构如下:
在这里插入图片描述

由上图可知,Aurora 64B66B IP核由四个核心模块构成,协同实现链路初始化、数据编解码及流控制:

通道逻辑(Lane Logic)
功能:驱动每个GT收发器(GTX/GTH/GTY),初始化收发器硬件,处理64B66B编解码、错误检测(如CRC校验)
关键操作:检测控制字符(如空闲符、时钟补偿符),确保数据对齐

全局逻辑(Global Logic)
功能:管理多通道绑定(Lane Bonding),验证通道同步状态,生成随机空闲字符维持链路活性,监控所有通道的错误(如hard_err硬件错误、soft_err位错误)
错误处理:检测到严重错误时自动复位并重新初始化通道

发送用户接口(TX User Interface)
接口类型:支持AXI4-Stream帧接口(带tlast/tkeep)或流接口(简化无帧控制)
功能:将应用层数据封装为Aurora帧(添加SCP/ECP控制符),插入时钟补偿序列(每10,000字节插入12字节开销)

接收用户接口(RX User Interface)
功能:解析输入数据流,剥离SCP/ECP控制符,恢复原始数据帧并通过AXI4-Stream输出;支持流量控制(如UFC/NFC)
特点:无弹性缓冲,依赖实时流控避免溢出

用户数据接口对比
Aurora 64B66B支持帧接口 (Framing) 流接口 (Streaming),对比如下:
在这里插入图片描述

Aurora 64B66B 发送流程

Aurora 64B66B用户发送数据使用帧接口(AXI4-Stream),包括以下流程:

用户发起传输
应用层置位s_axi_tx_tvalid并输出数据至s_axi_tx_tdata,同时用s_axi_tx_tlast标识帧结束,s_axi_tx_tkeep标记末尾有效字节

IP核组帧
当s_axi_tx_tready与s_axi_tx_tvalid同时有效时,IP核采样数据

组帧规则:
帧首添加2字节SCP(Start Channel Protocol)
帧尾添加2字节ECP(End Channel Protocol)
若数据字节数为奇数,末尾补PAD字符

插入控制序列
在数据间隙插入空闲字符或时钟补偿序列(CC),优先级高于数据传输
发送过程中可通过拉低s_axi_tx_tvalid暂停传输(流控)

串行化输出
数据经GT收发器进行64B66B编码,转为串行信号通过物理链路发送

使用总结
以上流程为Aurora 64B66B IP核内部实现,开发者只需了解即可,无需关心起具体实现细节,开发者只需把发送数据转换为AXI4-Stream数据流送入Aurora 64B66B用户发送接口即可;

Aurora 64B66B 接收流程

数据解析
GT收发器接收串行数据,进行字对齐和64B66B解码
通道逻辑检测并剥离SCP、ECP、PAD及空闲字符,提取有效负载

帧恢复与输出
恢复的数据通过AXI4-Stream接口输出:
m_axi_rx_tvalid标识有效数据
m_axi_rx_tlast标识帧结束
m_axi_rx_tkeep标记帧末有效字节(仅当tlast有效时)
无流控信号:接收端无tready,需应用层实时消费数据

错误检测
实时监测编解码错误(置位soft_err)或帧结构错误(如连续SCP,置位frame_err)

使用总结
以上流程为Aurora 64B66B IP核内部实现,开发者只需了解即可,无需关心起具体实现细节,开发者只需把Aurora 64B66B IP核输出的AXI4-Stream数据流送入自己的接收模块即可进行具体分析和处理;

Aurora 64B66B 时钟架构

Aurora 64B66B IP核涉及多时钟域协同,关键时钟信号如下:
在这里插入图片描述
时钟交互要点:
跨时钟域同步:INIT_CLK用于复位逻辑(gt_reset需同步至该时钟域),避免亚稳态
用户时钟生成:USER_CLK由GT收发器的CDR(时钟数据恢复)电路产生,确保与输入数据同步
抖动要求:参考时钟(GT_REFCLK)需满足严格抖动限制(通常<1 ps RMS),否则高线速下链路失锁

Aurora 64B66B IP核调用和使用

Aurora 8B10B IP核配置调用在工程种位置如下:
在这里插入图片描述
Aurora 64B66B IP核调用和使用很简单,通过vivado的UI界面即可完成,如下:
在这里插入图片描述
然后配置如下:
在这里插入图片描述
具体配置要根据自己的项目需求而定,上图只是博主的配置,仅供参考;

用户数据接收模块

用户数据接收模块在工程中位置如下:
在这里插入图片描述
接收AXI4-Stream流然后进入纯verilog代码实现的用户数据接收比对模块,实现接收数据与发送数据的逐个比较;最后将比较结果输出功设计者分析判断;整个工程实用性拉满,对于有Aurora 64B66B开发需求的用户可谓精准适配;
用户数据接收模块顶层接口如下:
在这里插入图片描述

工程源码架构

提供2套工程源码,以工程源码1为例,综合后的工程源码架构如下:
在这里插入图片描述

工程仿真

工程代码中已提供了仿真,可在vivado中直接仿真,操作如下:
在这里插入图片描述
仿真结果如下:
在这里插入图片描述

4、vivado工程源码1详解–>Kintex7-325T版本

开发板FPGA型号:Kintex7–35T–xc7k325tffg676-2;
FPGA开发环境:Vivado2019.1;
输入:FPGA内部生成的发送数据帧;
输出:FPGA内部做收发数据比对,并输出比对结果;
光编码方案:Xilinx Aurora 64B66B IP核;
回环光口类型:1路SFP光口;
高速收发器类型:GTX,线速率5Gbps;
Aurora 64B66B用户数据位宽:64 bit;
实现功能:FPGA实现Aurora 64B66B数据回环传输;
工程作用:此工程目的是让读者掌握FPGA实现Aurora 64B66B数据回环传输的设计能力,以便能够移植和设计自己的项目;
工程Block Design和工程代码架构请参考第3章节的《工程源码架构》小节内容;
工程的资源消耗和功耗如下:
在这里插入图片描述

5、vivado工程源码2详解–>Zynq7100版本

开发板FPGA型号:Zynq7100–xc7z100ffg900-2;
FPGA开发环境:Vivado2019.1;
输入:FPGA内部生成的发送数据帧;
输出:FPGA内部做收发数据比对,并输出比对结果;
光编码方案:Xilinx Aurora 64B66B IP核;
回环光口类型:1路SFP光口;
高速收发器类型:GTX,线速率5Gbps;
Aurora 64B66B用户数据位宽:64 bit;
实现功能:FPGA实现Aurora 64B66B数据回环传输;
工程作用:此工程目的是让读者掌握FPGA实现Aurora 64B66B数据回环传输的设计能力,以便能够移植和设计自己的项目;
工程Block Design和工程代码架构请参考第3章节的《工程源码架构》小节内容;
工程的资源消耗和功耗如下
在这里插入图片描述

6、工程移植说明

vivado版本不一致处理

1:如果你的vivado版本与本工程vivado版本一致,则直接打开工程;
2:如果你的vivado版本低于本工程vivado版本,则需要打开工程后,点击文件–>另存为;但此方法并不保险,最保险的方法是将你的vivado版本升级到本工程vivado的版本或者更高版本;
在这里插入图片描述
3:如果你的vivado版本高于本工程vivado版本,解决如下:
在这里插入图片描述
打开工程后会发现IP都被锁住了,如下:
在这里插入图片描述
此时需要升级IP,操作如下:
在这里插入图片描述
在这里插入图片描述

FPGA型号不一致处理

如果你的FPGA型号与我的不一致,则需要更改FPGA型号,操作如下:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
更改FPGA型号后还需要升级IP,升级IP的方法前面已经讲述了;

其他注意事项

1:由于每个板子的DDR不一定完全一样,所以MIG IP需要根据你自己的原理图进行配置,甚至可以直接删掉我这里原工程的MIG并重新添加IP,重新配置;
2:根据你自己的原理图修改引脚约束,在xdc文件中修改即可;
3:纯FPGA移植到Zynq需要在工程中添加zynq软核;

7、上板调试验证

准备工作

需要准备的器材如下:
FPGA开发板,没有开发板可以找本博提供;
SFP光模块和光纤;
我的开发板了连接如下:
在这里插入图片描述

Aurora 64B66B光口数据回环效果演示

Aurora 64B66B光口数据回环效果演示如下:
在这里插入图片描述

8、工程代码的获取

代码太大,无法邮箱发送,以某度网盘链接方式发送,
资料获取方式:文章末尾的V名片。
网盘资料如下:
在这里插入图片描述
此外,有很多朋友给本博主提了很多意见和建议,希望能丰富服务内容和选项,因为不同朋友的需求不一样,所以本博主还提供以下服务:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/918520.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/918520.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

实用硬件设计规范要点-原理图

此处所涉及的并非指导硬件工程师如何绘制原理图&#xff0c;而是旨在规范原理图的模板&#xff0c;统一原理图的设计方式&#xff0c;确保原理图具备良好的可阅读性&#xff0c;并统一与下一环节——PCB LAYOUT的接口。具体的硬件设计方法&#xff0c;诸位需在未来的工作中加以…

用 Apache Iceberg 与 Apache Spark 在 Google Cloud 打造高性能、可扩展的数据湖仓

大数据分析版图不断演进&#xff0c;组织正寻求更灵活、可扩展且具成本效益的方式来管理与分析海量数据。这一追求催生了数据湖仓范式&#xff0c;它将数据湖的低成本存储与灵活性&#xff0c;与数据仓库的数据管理能力和事务一致性相结合。站在这场变革中心的是 Apache Iceber…

【PyTorch学习笔记 - 02】 Datasets DataLoaders

前言 处理数据样本的代码可能会变得杂乱无章且难以维护&#xff1b;为了获得更好的可读性和模块化&#xff0c;我们理想的情况是将数据集代码与模型训练代码解耦。PyTorch 提供了两个数据处理类&#xff1a; torch.utils.data.DataLoader 和 torch.utils.data.Dataset&#x…

JavaWeb 30 天入门:第七天 —— 异常处理机制

在前六天的学习中&#xff0c;我们掌握了 Java 的基础语法、面向对象核心特性、抽象类与接口等知识。今天我们将学习 Java 中的异常处理机制&#xff0c;这是保证程序健壮性的关键技术。在 JavaWeb 开发中&#xff0c;无论是用户输入错误、数据库连接失败还是网络异常&#xff…

编译器默认生成的c++类六大成员函数

编译器默认生成的c类六大成员函数 编译器默认生成的六大成员函数 当你定义一个空类时&#xff0c;例如&#xff1a; class Empty {};如果代码中没有显式定义任何成员函数&#xff0c;C编译器会在需要时&#xff08;例如&#xff0c;代码中实际调用了这些函数&#xff09;为你…

人工智能概念:常见的大模型微调方法

文章目录一、微调技术的底层逻辑1.1 预训练与微调的关系1.2 核心目标&#xff1a;适配任务与数据二、经典微调方法详解2.1 全量微调&#xff08;Full Fine-Tuning&#xff09;2.2 冻结层微调&#xff08;Layer-Freezing Fine-Tuning&#xff09;2.3 参数高效微调&#xff08;Pa…

动态路由协议(一)

1. 动态路由 概述 静态路由在大网络里太麻烦&#xff08;设备多、配置量大&#xff0c;拓扑变了还要手动改&#xff09; 静态路由是由工程师手动配置和维护的路由条目&#xff0c;命令行简单明确&#xff0c;适用于小型或稳定的网络。静态路由有以下问题&#xff1a; 无法适…

LINUX812 shell脚本:if else,for 判断素数,创建用户

问题 [rootweb ~]# for((i2;i<n;i)) > if [ $n -ne $i ] && [ $((n%i)) -eq 0 ];then -bash: 未预期的符号 if 附近有语法错误 您在 /var/spool/mail/root 中有邮件 [rootweb ~]#[rootweb ~]# cat judgeprimeok.sh declare -i n read -p "please type the n…

游戏中角色持枪:玩家操控角色,角色转向时枪也要转向

角色持有枪&#xff0c;玩家&#xff08;你&#xff09;操控角色&#xff0c;那么&#xff0c;在角色转向时&#xff0c;枪也要转向。 先看看简单情况&#xff1a;假定角色只面向左或右方向&#xff0c;pygame中用这句来实现&#xff1a;pos self.facing * self.gun_offset s…

深度学习入门Day8:生成模型革命——从GAN到扩散模型

一、开篇&#xff1a;创造力的算法革命从昨天的Transformer到今天的生成模型&#xff0c;我们正从"理解"世界迈向"创造"世界。生成对抗网络(GAN)和扩散模型(Diffusion Model)代表了当前生成式AI的两大主流范式&#xff0c;它们让机器能够生成逼真的图像、音…

基于WRF-Chem的不同气溶胶的辐射效应的研究

前言目前我对于气溶胶辐射效应的理解就是设计敏感性实验&#xff0c;基础实验打开气溶胶参与辐射开关&#xff08;aer_ra_feedback&#xff09;&#xff0c;其他的实验则关闭气溶胶参与辐射过程开关&#xff0c;也有去掉某些气溶胶的影响&#xff0c;如黑碳&#xff08;BC&…

专题:2025人形机器人与服务机器人技术及市场报告|附130+份报告PDF汇总下载

原文链接&#xff1a;https://tecdat.cn/?p43583 当特斯拉Optimus在工厂里精准分拣电池&#xff0c;当普渡机器人在酒店完成跨楼层配送&#xff0c;一个万亿级的智能革命正在拉开序幕。服务机器人与人形机器人不再是实验室里的概念&#xff0c;而是正在重塑制造业、服务业的“…

JS 模块化与打包工具

一、模块化体系&#xff1a;ESM vs CJS 深入1.语法与静态性(1)ESM:静态语法&#xff0c;可被打包器做 Tree-shakingexport function play() {}export default ...import { play } from ./mod.js(2)CJS:运行时 require() , 分析能力弱&#xff0c;不利于 Tree-shaking2.Node 解析…

防御保护11

带宽管理 --- 设备对自身的流量进行管理和控制&#xff0c;去提供带宽保证、带宽限制等等功能。 带宽限制 带宽保证 连接数限制 应用场景 实现带宽管理 带宽通道 --- 定义了被管理对象所能使用的带宽资源 整体的保证带宽和最大带宽&#xff1b; SW1-SW2&#xff1a;VLAN 201 --…

[激光原理与应用-254]:理论 - 几何光学 - 自动对焦的原理

自动对焦&#xff08;Auto Focus, AF&#xff09;是现代光学系统&#xff08;如相机、手机摄像头、监控设备等&#xff09;的核心功能之一&#xff0c;其原理是通过检测成像面的清晰度或测量物体距离&#xff0c;驱动透镜组移动至最佳对焦位置。以下是自动对焦的详细原理及技术…

【Python办公】Mermaid代码转图片工具 - Tkinter GUI版本

目录 专栏导读 项目简介 功能特性 🎨 直观的图形界面 📝 代码编辑功能 🖼️ 图片生成与预览 💾 文件操作 ⚡ 性能优化 技术架构 核心技术栈 架构设计 安装与使用 环境要求 依赖安装 运行程序 使用步骤 代码示例 基本流程图 时序图 甘特图 核心代码解析 1. 主类结构 2. …

【Activiti】要点初探

Activiti 7.0.0配置 流程配置节点流程XML流程部署部署后会操作表&#xff1a;&#xff08;每部署一次增加一条记录&#xff09; ACT_RE_DEPLOYMENT 流程定义部署表 ACT_RE_PROCDEF 流程定义表 ACT_GE_BYTEARRAY 流程启动查看任务&#xff08;张三要查看准备办理任务&#xff0…

VBS 字符串处理

一. 字符串是由Unicode字符组成的一串字符。通常由数字&#xff0c;字母&#xff0c;符号组成。二. 常用函数1. 消除空格 Ltrim: 删除字符串左侧的空格。 Rtrim: 删除字符串右侧的空格。 trim: 删除字符串左侧和右侧的空格。a" hello " b"sx"msgbo…

《算法导论》第 21 章-用于不相交集合的数据结构

引言不相交集合&#xff08;Disjoint Set&#xff09;&#xff0c;也称为并查集&#xff08;Union-Find&#xff09;&#xff0c;是一种非常实用的数据结构&#xff0c;主要用于处理一些元素分组的问题。它支持高效的集合合并和元素查找操作&#xff0c;在很多算法中都有重要应…

基于51单片机RFID智能门禁系统红外人流量计数统计

1 系统功能介绍 本设计基于STC89C52单片机&#xff0c;集成RFID读卡器、红外避障传感器、继电器、LCD1602液晶显示和蜂鸣器&#xff0c;实现智能门禁与人流量统计功能。系统能够识别合法的RFID卡开门&#xff0c;并实时统计通过人数&#xff0c;具有安全报警和直观显示功能。具…