FPGA:如何提高RTL编码能力?
要提升RTL(寄存器传输级)编码能力,需从硬件设计思维建立、典型电路建模、编码规范掌握、工具链应用和工程实践五个维度系统性训练。以下是具体提升路径:
一、建立硬件设计思维:理解RTL与软件的本质区别
RTL代码最终会映射为具体的硬件电路(门电路、寄存器、多路选择器等),这与软件的“顺序执行”有本质差异。初学者需重点理解:
- 并行性:RTL中
always
块的并列关系对应硬件电路的并行执行(如多个组合逻辑模块同时工作),而begin...end
内的顺序语句仅用于描述同一电路的信号赋值关系。 - 时序约束:
posedge clk
触发的时序逻辑决定寄存器的更新时刻,需明确“寄存器如何捕获信号”“建立保持时间”等概念。 - 资源映射:每条RTL语句会对应具体的FPGA资源(如
assign a = b & c
对应LUT查找表;reg [3:0] cnt
对应4个触发器)。可通过综合报告(如Xilinx Vivado的Utilization Report
)验证代码与资源的映射关系。
二、掌握典型数字电路的RTL建模方法
FPGA设计中90%的场景可归类为组合逻辑、时序逻辑和状态机三类电路。需针对性训练其标准编码模板:
1. 组合逻辑(无记忆功能)
- 核心特征:输出仅由当前输入决定,无寄存器存储状态。
- 典型应用:数据选择(MUX)、算术运算(加法器)、逻辑门。
- 标准编码:
// 方式1:assign连续赋值(推荐) assign out = (sel) ? in_a : in_b; // 方式2:always@(*)块(需避免锁存器) always@(*) beginif(sel) out = in_a;else out = in_b; // 必须覆盖所有输入情况,否则综合出锁存器 end
- 避坑提示:组合逻辑中
if/else
或case
语句必须覆盖所有可能的输入条件,否则会因“未定义状态”综合出非预期的锁存器(Latch)。
2. 时序逻辑(有记忆功能)
- 核心特征:输出由当前输入和寄存器状态共同决定,依赖时钟边沿触发。
- 典型应用:计数器、移位寄存器、数据缓存。
- 标准编码:
// 同步复位(推荐:符合FPGA时序优化需求) always@(posedge clk) beginif(rst_n) begin // 复位信号低有效cnt <= 4'd0; // 复位时计数器清零end else begincnt <= cnt + 1'd1; // 时钟上升沿触发计数end end// 异步复位(仅在需要严格时序时使用) always@(posedge clk or negedge rst_n) beginif(!rst_n) cnt <= 4'd0; else cnt <= cnt + 1'd1; end
- 避坑提示:
- 时序逻辑中
<=
(非阻塞赋值)用于描述寄存器行为,=
(阻塞赋值)仅用于组合逻辑。 - 优先使用同步复位(复位信号与时钟同步),便于工具进行时序优化;异步复位需额外处理亚稳态风险。
- 时序逻辑中
3. 状态机(有限状态机,FSM)
- 核心特征:通过状态转移实现复杂逻辑控制,是数字系统的“大脑”。
- 典型应用:通信协议解析(如UART、SPI)、数据处理流程控制。
- 标准编码(三段式状态机):
parameter IDLE = 3'd0, S1 = 3'd1, S2 = 3'd2, DONE = 3'd3;// 第一段:状态寄存器(时序逻辑) reg [2:0] current_state, next_state; always@(posedge clk or negedge rst_n) beginif(!rst_n) current_state <= IDLE;else current_state <= next_state; end// 第二段:状态转移条件(组合逻辑) always@(*) beginnext_state = IDLE; // 默认状态防锁存case(current_state)IDLE: if(start) next_state = S1;S1: next_state = S2;S2: if(finish) next_state = DONE;DONE: next_state = IDLE;default: next_state = IDLE;endcase end// 第三段:输出逻辑(时序/组合可选,推荐时序) reg out_valid; always@(posedge clk) beginout_valid <= (current_state == DONE); // 时序输出避免毛刺 end
- 避坑提示:
- 使用独热码(One-Hot)编码状态(如3状态用3’b001、3’b010、3’b100),可减少状态译码逻辑(FPGA中LUT资源更丰富,独热码比二进制码更高效)。
- 状态转移条件需覆盖所有可能(
default
分支必加),避免状态机卡死。 - 输出逻辑优先用时序电路(
always@(posedge clk)
),避免组合逻辑输出的毛刺(Glitch)影响后级电路。
三、严格遵守RTL编码规范:避免综合陷阱
FPGA综合工具(如Vivado)对RTL代码的“语法宽容度”有限,不规范的代码可能导致综合结果与设计意图不符(如生成冗余逻辑、时序不收敛)。以下是必须掌握的规范:
1. 信号类型规范
- 输入/输出定义:明确
input
/output
的方向,inout
用于双向信号(如I2C的SDA)。 - 寄存器/线网区分:
reg
类型用于时序逻辑或always@(*)
组合逻辑的输出;wire
类型用于assign
连续赋值的信号。 - 位宽匹配:避免不同位宽信号直接运算(如
4'b1111 + 2'b11
会导致位宽扩展错误),需显式位宽转换({2'b0, 2'b11}
)。
2. 避免不可综合的语法
以下代码在仿真中有效,但无法综合为实际硬件电路:
- 递归函数(
function
内调用自身) - 延迟赋值(
#10 a = b
,实际电路无法实现精确延迟) - 动态数组(
reg [7:0] arr[]
,FPGA无法分配可变大小的存储资源) fork...join
并行块(仅用于仿真的多线程描述)
3. 时钟与复位规范
- 时钟域:避免异步时钟交叉(如两个不同频率的时钟直接交互),需通过同步器(如双触发器)处理跨时钟域信号。
- 复位策略:全系统统一复位信号(如
rst_n
),避免局部使用不同复位源导致时序混乱。
四、通过“分析-复现-优化”提升代码质量
1. 分析优秀开源代码
- 参考资源:Xilinx官方IP的RTL实现(如
AXI4
接口、FIFO
)、开源项目(如LiteX
、Chisel
转换的Verilog)。 - 重点关注:
- 如何用RTL实现高效的资源复用(如乘法器分时复用)。
- 状态机如何处理边界条件(如异常中断、错误恢复)。
- 跨时钟域信号的处理(如异步FIFO的
rd_ptr
/wr_ptr
格雷码转换)。
2. 复现经典电路并对比综合结果
例如:实现一个16位计数器,分别尝试以下三种方式,通过综合报告对比资源消耗:
- 纯加法器实现(
cnt <= cnt + 1
) - 移位寄存器实现(
cnt <= {cnt[14:0], 1'b1}
) - 二进制码转格雷码输出(减少跨时钟域翻转次数)
通过对比可直观理解“不同编码方式对LUT/FF资源的影响”。
3. 学习工具反馈:利用综合报告优化代码
- 查看Utilization Report:明确代码消耗了多少LUT、FF、BRAM等资源,定位“资源消耗过高”的模块(如某
case
语句占用了30个LUT)。 - 分析Timing Report:通过
Setup/Hold Violation
定位时序瓶颈(如关键路径上的加法器延迟过长),优化方法包括:- 流水线(Pipelining):将长组合逻辑拆分为多级寄存器级联。
- 资源共享(Resource Sharing):分时复用乘法器。
- 并行化(Parallelism):用多个加法器替代串行运算。
五、工程实践:从模块级到系统级设计
1. 模块级训练(入门阶段)
选择小而精的功能模块(如UART收发器、PWM发生器),严格按照以下流程实现:
- 需求拆解:明确接口(
clk
、rst_n
、tx_data
、rx_done
等)、时序(如波特率115200对应时钟周期数)。 - RTL编码:使用三段式状态机实现核心逻辑,添加
ifdef SIM
仿真测试平台。 - 仿真验证:用ModelSim或Xilinx ISim验证功能(如发送
0x55
并检查接收端是否正确解析)。 - 综合实现:在Vivado中综合,查看资源消耗和时序是否满足(如时钟频率是否达到50MHz)。
- 上板验证:通过ILA(集成逻辑分析仪)抓取实际信号,确认硬件行为与仿真一致。
2. 系统级训练(进阶阶段)
尝试设计一个完整的系统(如基于FPGA的数字示波器),整合多个模块:
- 接口模块:AD转换(如ADC0809控制)、VGA显示(1024x768@60Hz时序生成)。
- 算法模块:数据采集(滑动窗口滤波)、FFT频谱分析(调用Xilinx FFT IP)。
- 控制模块:通过状态机协调采样、处理、显示流程。
系统级设计能帮助理解模块间时序配合(如AD采样时钟与处理模块时钟的同步)、资源分配(如BRAM用于缓存采样数据)和功耗优化(如关闭空闲模块的时钟门控)。
总结:提升RTL能力的“三步法”
- 打基础:理解RTL与硬件的映射关系,掌握组合/时序逻辑、状态机的标准编码。
- 练分析:通过阅读优秀代码、对比综合报告,学习资源优化技巧。
- 做项目:从模块级到系统级实践,积累工程经验(如时序收敛、跨时钟域处理)。
坚持“编码-仿真-综合-上板”的闭环验证,逐步形成“写代码时能预判电路结构,看综合报告能反推代码问题”的能力,RTL编码水平会显著提升。
相关文章:
FPGA:如何提高RTL编码能力?
要提升RTL(寄存器传输级)编码能力,需从硬件设计思维建立、典型电路建模、编码规范掌握、工具链应用和工程实践五个维度系统性训练。以下是具体提升路径: 一、建立硬件设计思维:理解RTL与软件的本质区别 RTL代码最终会…...
高频微服务面试题总结
微服务基础概念 什么是微服务架构? 将单一应用拆分为一组小型服务每个服务运行独立进程,轻量级通信独立开发、部署和扩展特点:松耦合、独立技术栈、独立数据库微服务与单体架构对比 维度单体架构微服务架构开发效率初期快初期慢部署整体部署独立部署扩展性整体扩展细粒度扩展…...
【RAG】Milvus、Pinecone、PgVector向量数据库索引参数优化
Milvus 、PgVector 索引参数优化 IVF类索引关键参数(基于聚类算法) nlist (倒排列表数量): 决定将向量空间划分为多少个聚类中心值越大搜索越精确但耗时越长推荐值: 通常设置为数据量的4√n到n/1000之间例如: 1百万数据量可设nlist1000到4000 nprobe (…...
基金基础知识-指数基金 | 投资理财(4) 【待续】
基金通常是由股票、债券等多种资产组合而成的投资工具,核心是分散化,将资金投向一篮子资产(动态),避免单一资产的风险。 按投资标的分类: 基金类型 相当于 特点 适合人群 货币基金 活期钱包&…...
【K8S系列】Kubernetes常用 命令
以下为的 Kubernetes 超全常用命令文档,涵盖集群管理、资源操作、调试排错等核心场景,结合示例与解析, 高效运维 Kubernetes 环境。 一、集群与节点管理 1. 集群信息查看 查看集群基本信息kubectl cluster-info # 显示API Server、DNS等核…...
高性能编程相关
常见高性能编程技巧: 一,系统级性能优化:从系统架构设计考虑,例如消息队列,模块分成分级,IO读写带宽等 二,算法级性能优化:时间和空间优化 三,代码级性能优…...
使用 NV‑Ingest、Unstructured 和 Elasticsearch 处理非结构化数据
作者:来自 Elastic Ajay Krishnan Gopalan 了解如何使用 NV-Ingest、Unstructured Platform 和 Elasticsearch 为 RAG 应用构建可扩展的非结构化文档数据管道。 Elasticsearch 原生集成了行业领先的生成式 AI 工具和提供商。查看我们的网络研讨会,了解如…...
k8s之statefulset
什么是statefulset(sts) statefulset是用来管理有状态应用的工作负载API对象,也是一种工作负载资源 有状态和无状态 无状态应用:当前应用不会记录状态(网络可能会变、挂载的东西可能会变、顺序可能会变) 有状态应用:需要记录当前状态(网络不变、存储不变、顺序不变) 使…...
在自然语言处理任务中,像 BERT 这样的模型会在输入前自动加上一些特殊token
🌱 1. 什么是 BERT? BERT 是一个自然语言理解模型。你可以把它想象成一个超级聪明的“语言理解机器人”。你把一句话丢进去,它能: 理解这句话的意思;告诉你哪个词是实体(人名、地名)ÿ…...
java学习笔记
Java 方法返回值 Java 是一种强类型语言,方法在定义时必须明确指定返回值的类型。 这确保了类型安全和代码的可预测性. 方法返回值不能缺省。 必须显式声明返回类型. 如果方法没有返回值,需要使用 void 关键字来表示。 void 意味着该方法执行某些操作但不返回任何值。 访问修…...
动态规划--两个数组的dp问题
目录 1 最长公共子序列 2 最长回文子序列 3 不相交的线 4 不同的子序列 5 通配符匹配 6 正则表达式匹配 7 交错字符串 8 两个字符串的最小ASCII删除和 9 最长重复子数组 本文主要讲解两个数组的动态规划问题的几个经典例题,希望看完本文之后能够对大家做这…...
Xcavate 上线 Polkadot |开启 Web3 房地产投资新时代
在传统资产 Tokenization 浪潮中,Xcavate 以房地产为切口迅速崛起。作为 2023 年 OneBlock 冬季波卡黑客松冠军,Xcavate 凭借创新的资产管理与分发机制,在波卡生态中崭露头角。此次主网上线,标志着 Xcavate 正式迈入全球化应用阶段…...
在企业级项目中高效使用 Maven-mvnd
1、引言 1.1 什么是 Maven-mvnd? Maven-mvnd 是 Apache Maven 的一个实验性扩展工具(也称为 mvnd),基于守护进程(daemon)模型构建,目标是显著提升 Maven 构建的速度和效率。它由 Red Hat 推出,通过复用 JVM 进程来减少每次构建时的启动开销。 1.2 为什么企业在构建过…...
[论文阅读]Deeply-Supervised Nets
摘要 我们提出的深度监督网络(DSN)方法在最小化分类误差的同时,使隐藏层的学习过程更加直接和透明。我们尝试通过研究深度网络中的新公式来提升分类性能。我们关注卷积神经网络(CNN)架构中的三个方面:&…...
使用零样本LLM在现实世界环境中推广端到端自动驾驶——论文阅读
《Generalizing End-To-End Autonomous Driving In Real-World Environments Using Zero-Shot LLMs》2024年12月发表,来自纽约stony brook大学、UIC和桑瑞思(数字化医疗科技公司)的论文。 传统的自动驾驶方法采用模块化设计,将任务…...
多视图密集对应学习:细粒度3D分割的自监督革命
原文标题:Multi-view Dense Correspondence Learning (MvDeCor) 引言 在计算机视觉与图形学领域,3D形状分割一直是一个基础且具有挑战性的任务。如何在标注稀缺的情况下,实现对3D模型的细粒度分割?近期,斯坦福大学视觉…...
【论文阅读】——Articulate AnyMesh: Open-Vocabulary 3D Articulated Objects Modeling
文章目录 摘要一、介绍二、相关工作2.1. 铰接对象建模2.2. 部件感知3D生成 三、方法3.1. 概述3.2. 通过VLM助手进行可移动部件分割3.3. 通过几何感知视觉提示的发音估计3.4. 通过随机关节状态进行细化 四、实验4.1. 定量实验发音估计设置: 4.2. 应用程序 五、结论六、思考 摘要…...
Docker Compose 的详细使用总结、常用命令及配置示例
以下是 Docker Compose 的详细使用总结、常用命令及配置示例,帮助您快速掌握这一容器编排工具。 一、Docker Compose 核心概念 定位:用于定义和管理多容器 Docker 应用,通过 YAML 文件配置服务、网络、卷等资源。核心概念: 服务 …...
2025.05.08-得物春招研发岗-第三题
📌 点击直达笔试专栏 👉《大厂笔试突围》 💻 春秋招笔试突围在线OJ 👉 笔试突围OJ 03. 矩阵魔法变换 问题描述 A先生是一位著名的魔法师,他最近发明了一种特殊的矩阵魔法。这种魔法可以同时改变矩阵中特定区域内所有元素的值。 A先生有一个 n m n \times m...
【Spring AI 实战】基于 Docker Model Runner 构建本地化 AI 聊天服务:从配置到函数调用全解析
【Spring AI 实战】基于 Docker Model Runner 构建本地化 AI 聊天服务:从配置到函数调用全解析 前沿:本地化 AI 推理的新范式 随着大语言模型(LLM)应用的普及,本地化部署与灵活扩展成为企业级 AI 开发的核心需求。Do…...
【数据机构】2. 线性表之“顺序表”
- 第 96 篇 - Date: 2025 - 05 - 09 Author: 郑龙浩/仟墨 【数据结构 2】 文章目录 数据结构 - 2 -线性表之“顺序表”1 基本概念2 顺序表(一般为数组)① 基本介绍② 分类 (静态与动态)③ 动态顺序表的实现**test.c文件:****SeqList.h文件:****SeqList.c文件:** 数据结构 - 2 …...
Django ORM: values() 和 annotate() 方法详解
1. values()方法 1.1 基本概念 values()方法用于返回一个包含字典的QuerySet,而不是模型实例。每个字典表示一个对象,键对应于模型字段名称。 1.2 基本用法 # 获取所有书籍的标题和出版日期 from myapp.models import Bookbooks Book.objects.value…...
数据结构篇-二叉树
抽象定义CFG文法具体表示基本操作性质 抽象定义 二叉树是一个抽象的数学概念。它的定义是递归的 一棵二叉树可以是一个外部节点,一棵二叉树可以是内部节点,连接到一对二叉树,分别是它的左子树,和右子树。 这个抽象定义描述了二…...
前端面试每日三题 - Day 29
这是我为准备前端/全栈开发工程师面试整理的第29天每日三题练习: ✅ 题目1:Web Components技术全景解析 核心三要素 Custom Elements(自定义元素) class MyButton extends HTMLElement {constructor() {super();this.attachShado…...
Java设计模式之抽象工厂模式:从入门到精通
一、抽象工厂模式概述 抽象工厂模式(Abstract Factory Pattern)是一种创建型设计模式,它提供了一种创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类。 1.1 专业定义 抽象工厂模式定义了一个工厂接口,用于创建一系列相关或依赖的对象,客户端通过调用抽象工…...
Rust中记录日志:fast_log
在Rust程序中记录日志,可以使用fast_log。 根据fast_log 的介绍,这是一个性能非常高的日志实现,还支持文件追加模式、压缩、切分与回滚等操作。 而且,这个库记录日志是异步的,即不会因为日志而影响程序的运行。只有当…...
构筑芯片行业的“安全硅甲”
在半导体行业,数据就是生命线。一份芯片设计图纸的泄露,可能让企业数亿研发投入付诸东流;一段核心代码的外传,甚至可能影响国家产业安全。然而,现实情况却是——许多芯片企业的数据防护,仍处于“裸奔”状态…...
C++ Dll创建与调用 查看dll函数 MFC 单对话框应用程序(EXE 工程)改为 DLL 工程
C Dll创建 一、添加 DllMain(必要) #include <fstream>void Log(const char* msg) {std::ofstream f("C:\\temp\\dll_log.txt", std::ios::app);f << msg << std::endl; }BOOL APIENTRY DllMain(HMODULE hModule, DWORD u…...
使用智能表格做FMEDA
一、优点 使用智能表格替代excel做FMEDA具备以下优势: 减少维护成本(数据库关联,修改方便)便于持续优化(失效率分布,失效率模型可重复使用)多人同步编写(同时操作,同步…...
电动汽车充换电设施可调能力聚合评估与预测 - 使用说明文档
电动汽车充换电设施可调能力聚合评估与预测 - 使用说明文档 概述 本脚本real_data_model.m基于论文《大规模电动汽车充换电设施可调能力聚合评估与预测》(鲍志远,胡泽春)实现了电动汽车充电设施的负荷预测和可调能力评估。使用混合模型(LSTM神经网络线…...
Tomcat 日志体系深度解析:从访问日志配置到错误日志分析的全链路指南
一、Tomcat 核心日志文件架构与核心功能 1. 三大基础日志文件对比(权威定义) 日志文件数据来源核心功能典型场景catalina.out标准输出 / 错误重定向包含 Tomcat 引擎日志与应用控制台输出(System.out/System.err)排查 Tomcat 启…...
MSF 生成不同的木马 msfvenom 框架命令
目录 什么是 msfvenom? 一、针对 Windows 的木马生成命令 1. EXE 格式(经典可执行文件) 2. VBS 脚本(Visual Basic Script) 3. PowerShell 脚本 4. DLL 文件(动态链接库) 5. Python 脚本…...
Linux云计算训练营笔记day05(Rocky Linux中的命令:管道操作 |、wc、find、vim)
管道操作 | 作用: 将前面命令的输出,传递给后面命令,作为后面命令的参数 head -3 /etc/passwd | tail -1 取第三行 head -8 /etc/passwd | tail -3 | cat -n 取6 7 8行 ifconfig | head -2 | tail -1 只查看IP地址 ifconfig | grep 192 过滤192的ip…...
【相机标定】OpenCV 相机标定中的重投影误差与角点三维坐标计算详解
摘要: 本文将从以下几个方面展开,结合典型代码深入解析 OpenCV 中的相机标定过程,重点阐述重投影误差的计算方法与实际意义,并通过一个 calcBoardCornerPositions() 函数详细讲解棋盘格角点三维坐标的构建逻辑。 在计算机视觉领域…...
传统销售VS智能销售:AI如何重构商业变现逻辑
如今最会赚钱的企业早就不靠堆人力了,他们都在悄悄用AI做商业变现。当普通销售还在手动记录客户信息时,AI销售系统已经能实时追踪客户在商品页的停留时长,甚至精确到秒。 传统客服人员还在机械地复制粘贴标准话术,AI销售却已经能根…...
从设计到开发,原型标注图全流程标准化
一、原型标注图是什么? 原型标注图(Annotated Prototype)是设计原型(Prototype)的详细说明书,通过图文结合的方式,将设计稿中的视觉样式、交互逻辑、适配规则等技术细节转化为开发可理解的标准…...
Mac QT水平布局和垂直布局
首先上代码 #include "mainwindow.h" #include "ui_mainwindow.h" #include <QPushButton> #include<QVBoxLayout>//垂直布局 #include<QHBoxLayout>//水平布局头文件 MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), …...
部署Superset BI(四)连接sql server数据库
sqlserver没有出现在Superset的连接可选菜单上,这一点让我奇怪。既然没有那就按着HANA的配置方式,照猫画虎。更奇怪的是安装好还不能出现,难道superset和微软有仇? --修改配置文件 rootNocobase:/usr/superset/superset# cd docke…...
Python爬虫(22)Python爬虫进阶:Scrapy框架动态页面爬取与高效数据管道设计
目录 一、背景:Scrapy在现代爬虫中的核心价值二、Scrapy项目快速搭建1. 环境准备与项目初始化2. 项目结构解析 三、动态页面处理:集成Splash与中间件1. 配置Splash渲染服务(Docker部署)2. 修改settings.py启用中间件3. 在Spider中…...
全球实物文件粉碎服务市场洞察:合规驱动下的安全经济与绿色转型
一、引言:从纸质堆叠到数据安全的“最后一公里” 在数字化转型浪潮中,全球企业每年仍产生超过1.2万亿页纸质文件,其中包含大量机密数据、客户隐私及商业敏感信息。据QYResearch预测,2031年全球实物文件粉碎服务市场规模将达290.4…...
使用Python 打造多格式文件预览工具 — 图、PDF、Word、Excel 一站式查看
在日常办公或文件管理场景中,我们经常面临这样的问题:在一个文件夹中短时间内产生了大量不同类型的文件(如图片、PDF、Word、Excel),我们需要快速浏览和筛选这些文件的内容,却不希望一个个打开它们。有没有…...
Microsoft 365 Copilot:为Teams在线会议带来多语言语音交流新体验
随着AI技术的飞速发展,Microsoft 365 Copilot将大型语言模型(LLM)与业务数据深度融合,为用户带来了前所未有的办公体验。在Teams在线会议中,Copilot不仅能够作为智能助手提升会议效率,还能通过实时辅助同声…...
c++:双向链表容器(std::list)
目录 🧱 一、什么是 std::list? ⚙️ 二、底层结构图解 🧪 三、list 的常见操作 📦 四、完整示例代码 📌 五、特点总结对比 🛠 六、特殊函数 📚 七、list 迭代器操作 ⚠️ 八、使用场景…...
jenkins 启动报错
java.lang.UnsatisfiedLinkError: /opt/application/jdk-17.0.11/lib/libfontmanager.so: libfreetype.so.6: cannot open shared object file: No such file or directory。 解决方案: yum install freetype-devel 安装完成之后重启jenkins。...
输入顶点坐标输出立方体长宽高的神经网络
写一个神经网络,我输入立方体投影线段的三视图坐标,输出分类和长宽高 import torch from torch import nn import torch.nn.functional as F# 假设每个视图有8个顶点,每个顶点有2个坐标值,因此每种视图有16个输入特征 input_dim…...
Layui表格行点击事件监听
在 Layui 中,如果想监听表格行的点击事件,可以通过以下步骤实现: 初始化表格:首先确保你已经使用 Layui 的 table.render 方法成功渲染了你的表格。绑定行点击事件:Layui 并没有直接提供针对表格行点击的事件监听器…...
2025数维杯数学建模竞赛B题完整参考论文(共38页)(含模型、代码、数据)
2025数维杯数学建模竞赛B题完整参考论文 目录 摘要 一、问题重述 二、问题分析 三、模型假设 四、定义与符号说明 五、 模型建立与求解 5.1问题1 5.1.1问题1思路分析 5.1.2问题1模型建立 5.1.3问题1求解结果 5.2问题2 5.2.1问题2思路分析 5.2.2问题2…...
TCP套接字通信核心要点
TCP套接字通信核心要点 通信模型架构 客户端-服务端模型 CS架构:客户端发起请求,服务端响应和处理请求双向通道:建立连接后实现全双工通信 服务端搭建流程 核心步骤 创建套接字 int server socket(AF_INET, SOCK_STREAM, 0); 参数说明&am…...
Android屏蔽通话功能和短信功能
需求开发中,有个要求屏蔽电话功能和短信功能,禁止应用打电话或短信,禁止api开发出的应用打电话或短信。这个约束怎么做呢? framework/base/core/res/res/values/config.xml.....<!-- Flag indicating whether the current devi…...
STM32TIM定时中断(6)
一、TIM介绍 1、TIM简介 TIM(Timer)定时器 定时器的基本功能:定时器可以对输入的时钟进行计数,并在计数值达到设定值时触发中断。 即定时触发中断,同时也可以看出,定时器就是一个计数器,当…...