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

Langchain .. 学习 --- LCEL和Runnable俅

一、什么是 Q 饱和运算1. 核心痛点普通运算的 “数值回绕”普通算术运算如 ADD/SUB溢出时数值会按补码规则 “回绕”导致结果完全错误示例int8_t 类型最大值 127 1 → 结果变成 -128而非预期的 127示例int8_t 类型最小值 -128 - 1 → 结果变成 127。2. Q 饱和运算的本质Q 饱和运算Saturating Arithmetic是 ARM 指令集中带 Q 前缀的特殊运算核心逻辑运算结果超出目标数据类型的数值范围上限 / 下限 时结果被 “钳位” 到该类型的极值同时置位 APSR 寄存器的 Q 标志位溢出标记。二、核心基础APSR 的 Q 标志位Q 饱和运算的 “溢出标记” 依赖 APSR应用程序状态寄存器的 Q 位这是使用饱和运算的核心要点1. Q 标志位关键属性特性 说明位位置 APSR 的 Bit 27唯一标识位触发条件 仅当 Q 前缀的饱和运算指令溢出时置 1普通运算溢出不触发粘性位特性 一旦置 1不会自动清零必须通过显式指令 / 代码清除否则会持续标记溢出2. 饱和运算的 “上下限”触发阈值Q 位触发的本质是运算结果超出目标数据类型的数值范围数据类型 符号性 下限 上限8 位整数 有符号 -128 1278 位整数 无符号 0 25516 位整数 有符号 -32768 3276732 位整数 有符号 -2147483648 2147483647三、核心用法饱和运算指令 / 函数1. 汇编层面直接操作深入底层ARM 提供了一系列带 Q 前缀的饱和运算指令入门常用指令如下指令 功能 适用场景QADD/QSUB 32 位有符号数饱和加 / 减 32 位整型数据运算UQADD8 无符号 8 位按字节饱和加法 多字节无符号数据如 RGBSQXTB 32 位→8 位有符号饱和转换 数据类型降位如 32→8 位UQXTB 32 位→8 位无符号饱和转换 无符号数据降位汇编示例32 位有符号饱和加法溢出场景; 目标计算int32_t上限值1验证饱和效果MOV R0, #2147483647 ; R0 int32_t上限值MOV R1, #1 ; 加1超出上限QADD R2, R0, R1 ; 饱和加法R2被钳位到2147483647Q位置1; 检测Q标志位MRS R3, APSR ; 读取APSR到R3TST R3, #(127) ; 检测Bit27Q位BNE overflow_handle ; Q1则跳转到溢出处理overflow_handle:MSR APSR_nzcvq, #0 ; 显式清除Q位关键避免后续误判2. C 语言层面快速入门推荐ARM GCC 编译器提供内置函数无需手写汇编底层自动生成 Q 前缀指令入门必用函数如下函数名 功能__qadd(a, b) 32 位有符号饱和加法__qsub(a, b) 32 位有符号饱和减法__sqxtb(a) 32 位→8 位有符号饱和转换__uqxtb(a) 32 位→8 位无符号饱和转换__SSAT(x, sat) 有符号数饱和至 sat 位__USAT(x, sat) 无符号数饱和至 sat 位C 语言完整示例含 Q 位检测 / 清除#include#include// 读取APSR寄存器检测Q标志位static inline uint32_t get_apsr(void) {uint32_t apsr;__asm__ volatile (mrs %0, apsr : r (apsr));return apsr;}// 判断Q位是否置1溢出static inline int is_q_flag_set(void) {return (get_apsr() (1U 27)) ! 0;}// 清除Q标志位static inline void clear_q_flag(void) {__asm__ volatile (msr apsr_nzcvq, #0);}int main(void) {// 示例限幅int32_t pid_output 50000; // 计算结果超出了16位变量范围// 将结果饱和限制在 16 位有符号数范围内 (-32768 ~ 32767)int16_t motor_output (int16_t)__SSAT(pid_output, 16);// 示例32位有符号饱和加法超出上限int32_t a 2147483647; // int32_t上限int32_t b 1;int32_t res1 __qadd(a, b); // 饱和加法结果钳位到2147483647printf(32位饱和加法结果%d预期2147483647\n, res1);printf(Q位状态%s\n, is_q_flag_set() ? 溢出置1 : 未溢出置0);clear_q_flag(); // 清除Q位return 0;}手动实现饱和运算兼容非 ARM GCC 场景若编译器不支持内置函数可手动判断范围实现简易饱和逻辑// 8位有符号数饱和加法int8_t sat_add_int8(int8_t a, int8_t b) {int16_t temp (int16_t)a (int16_t)b; // 用16位避免中间溢出if (temp 127) return 127; // 上限钳位if (temp -128) return -128; // 下限钳位return (int8_t)temp;}四、总结Q 饱和运算的核心是溢出时钳位到数据类型极值 置位 Q 标志位解决普通运算的 “数值回绕” 问题优先使用 ARM GCC 内置函数如__qadd深入调试可通过汇编操作 Q 位检测溢出需读取 APSR 的 Bit27关键注意点Q 位需手动清除、指令 / 函数匹配数据类型避免误判和结果错误。址召评倍

相关文章:

Langchain .. 学习 --- LCEL和Runnable俅

一、什么是 Q 饱和运算? 1. 核心痛点:普通运算的 “数值回绕” 普通算术运算(如 ADD/SUB)溢出时,数值会按补码规则 “回绕”,导致结果完全错误: 示例:int8_t 类型最大值 127 1 → 结…...

【技术解析】NeuPAN:如何用“白盒”端到端学习重塑机器人导航的精度与实时性

1. NeuPAN如何用"白盒"端到端学习颠覆传统导航 当你在商场里看到清洁机器人灵巧地绕过人群,或在仓库中目睹AGV小车以厘米级精度穿梭于货架之间时,背后很可能隐藏着一项突破性技术——NeuPAN框架。这个由"深度展开神经编码器(DUNE)"和…...

海外电网并网标准智能监测系统——设计与实现

海外电网并网标准智能监测系统——设计与实现 摘要 随着全球能源转型加速推进,各国电网并网标准持续快速演进。分布式能源(DER)、逆变器型资源(IBR)、储能系统的大规模接入正在推动并网技术规范的深刻变革。2025年至2026年间,美国NERC发布了多项针对IBR建模与验证的新标…...

Ryujinx开源Switch模拟器:跨平台游戏体验的技术实现与优化指南

Ryujinx开源Switch模拟器:跨平台游戏体验的技术实现与优化指南 【免费下载链接】Ryujinx 用 C# 编写的实验性 Nintendo Switch 模拟器 项目地址: https://gitcode.com/GitHub_Trending/ry/Ryujinx 在游戏硬件快速迭代的今天,玩家们常常面临一个困…...

【2026年最新600套毕设项目分享】微信小程序的订餐系统(30020)

有需要的同学,源代码和配套文档领取,加文章最下方的名片哦 一、项目演示 项目演示视频 二、资料介绍 完整源代码(前后端源代码SQL脚本)配套文档(LWPPT开题报告/任务书)远程调试控屏包运行一键启动项目&…...

【技术精讲】从理论到实践:手把手教你完成DFA最小化

1. 什么是DFA最小化?为什么需要它? 想象一下你正在整理一个杂乱无章的衣柜。有些衣服你从来不穿(死状态),有些衣服功能重复(等价状态)。DFA最小化就像给衣柜做断舍离,保留所有必要的…...

脚本管理工具怎么选?从3个维度重新认识ScriptCat与油猴

脚本管理工具怎么选?从3个维度重新认识ScriptCat与油猴 【免费下载链接】scriptcat ScriptCat, a browser extension that can execute userscript; 脚本猫,一个可以执行用户脚本的浏览器扩展 项目地址: https://gitcode.com/gh_mirrors/sc/scriptcat …...

2025届最火的降重复率助手解析与推荐

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 其核心在于模仿人类写作的自然特征,以此来降低AIGC检测率先,要调整词…...

突破格式壁垒:RePKG实现资源提取与格式转换的技术革命

突破格式壁垒:RePKG实现资源提取与格式转换的技术革命 【免费下载链接】repkg Wallpaper engine PKG extractor/TEX to image converter 项目地址: https://gitcode.com/gh_mirrors/re/repkg 在数字内容创作与游戏开发领域,资源处理往往面临着格式…...

Mysql的行级锁到底是怎么加的?匦

1. 架构背景与演进动力 1.1 从单体到碎片化:.NET 的开源征程 在.NET Framework 时代,构建系统主要围绕 Windows 操作系统紧密集成,采用传统的封闭式开发模式。然而,随着.NET Core 的推出,微软开启了彻底的开源与跨平台…...

JTAG接口原理与调试实战指南

1. JTAG接口基础解析与核心功能JTAG(Joint Test Action Group)作为现代数字系统开发中不可或缺的调试接口,其重要性往往被工程师们低估。这个诞生于1985年的IEEE 1149.1标准,最初是为了解决PCB板级互联测试难题,如今已…...

从TRCA到空间滤波器:解码稳态视觉诱发电位(SSVEP)的神经信号增强之道

1. 什么是SSVEP和TRCA? 想象一下,你正盯着一个以固定频率闪烁的LED灯。这时你的大脑视觉皮层会产生一种特殊的电信号,这种信号会神奇地跟随着灯的闪烁节奏,就像在跳踢踏舞一样。这就是稳态视觉诱发电位(SSVEP),它是脑机…...

ReadCat:重新定义数字阅读体验的现代开源阅读器

ReadCat:重新定义数字阅读体验的现代开源阅读器 【免费下载链接】read-cat 一款免费、开源、简洁、纯净、无广告的小说阅读器 项目地址: https://gitcode.com/gh_mirrors/re/read-cat 在信息过载的时代,我们需要的不仅是阅读工具,更是…...

从零构建ROS履带车:揭秘AI与无人驾驶核心技术(2)

1. 从零搭建ROS履带车的硬件基础 想要打造一台能跑能跳的智能履带车,第一步得把硬件架子搭结实。我当年第一次做履带车时,用的就是淘宝上200块钱的金属履带底盘套件,搭配Jetson Nano开发板作为大脑。这里有个实用建议:选择履带宽度…...

探索黑苹果实战:零基础打造你的专属 macOS 系统

探索黑苹果实战:零基础打造你的专属 macOS 系统 【免费下载链接】Hackintosh 国光的黑苹果安装教程:手把手教你配置 OpenCore 项目地址: https://gitcode.com/gh_mirrors/hac/Hackintosh 核心价值:为什么选择开源黑苹果项目 你是否曾…...

终极指南:如何免费让Figma界面全中文,设计师工作效率提升秘籍

终极指南:如何免费让Figma界面全中文,设计师工作效率提升秘籍 【免费下载链接】figmaCN 中文 Figma 插件,设计师人工翻译校验 项目地址: https://gitcode.com/gh_mirrors/fi/figmaCN FigmaCN是一款专为中文用户打造的免费本地化插件&a…...

网闸项目如何落地与验收?这份实战指南请收好!

网闸部署不仅是技术活,更是系统工程。从规划到验收,每个环节都关乎最终效果。以下是结合实战总结的实施方案与验收标准,助你高效推进项目!🚀📋 一、实施四步法​1️⃣ 需求分析与规划​✔ 业务梳理&#xf…...

亚马逊向忠实Kindle用户“致谢“:停止支持旧款设备

亚马逊正以停止支持旧款设备的方式"回馈"长期忠实的Kindle用户,但同时也试图以新设备八折优惠及电子书购书抵用金来"降低影响"。正如科技领域的规律——没有任何设备能永远获得支持。亚马逊在今日发送给用户的邮件中宣布,自2026年5月…...

低代码开发,降低成本的同时提升质量

一、低代码开发,企业数字化转型的新利器在当今数字化时代,企业面临着快速变化的市场环境和日益增长的业务需求。传统的软件开发方式往往需要耗费大量的时间、人力和物力,难以满足企业对应用系统的快速迭代和个性化需求。而低代码开发平台的出…...

AI赋能生物制药设备管理:智能运维筑牢质量合规核心防线

“生物反应器突发故障,批次发酵液报废损失超百万”“洁净区设备定期维护耗时数天,产线停摆影响产能”“无菌生产设备隐性隐患漏判,导致产品质量不达标面临召回”…… 生物制药行业作为高合规、高精准、高投入的特殊制造领域,设备是…...

Vue可视化打印设计终极指南:5分钟告别复杂代码,拖拽式布局惊艳全场

Vue可视化打印设计终极指南:5分钟告别复杂代码,拖拽式布局惊艳全场 【免费下载链接】vue-plugin-hiprint hiprint for Vue2/Vue3 ⚡打印、打印设计、可视化设计器、报表设计、元素编辑、可视化打印编辑 项目地址: https://gitcode.com/gh_mirrors/vu/v…...

行式存储(Row-based Storage)和列式存储(Column-base Storage)简介饲

1. 哑铃图是什么? 哑铃图(Dumbbell Plot),有时也称为DNA图或杠铃图,是一种用于比较两个相关数据点的可视化图表。 它源于人们对更有效数据比较方式的持续探索。 在传统的时间序列比较中,我们通常使用两条折…...

高效管理Windows驱动:Driver Store Explorer实战指南

高效管理Windows驱动:Driver Store Explorer实战指南 【免费下载链接】DriverStoreExplorer Driver Store Explorer 项目地址: https://gitcode.com/gh_mirrors/dr/DriverStoreExplorer Driver Store Explorer(简称RAPR)是一款专业开源…...

一文学习 Spring 声明式事务源码全流程总结碌

在之前的文章中,我们花了大量的篇幅,从记录后端pod真实ip开始说起,然后引入envoy,再解决了各种各样的需求:配置自动重载、流量劫持、sidecar自动注入,到envoy的各种能力:熔断、流控、分流、透明…...

算力 GPU 驱动实战总结:SVM Eviction Fence 设计思想与实现细节

1. 问题背景 1.1 STALE _mapcount 问题 在 VRAM 超量分配(overcommit)场景下,当 GPU VRAM 被占满时,TTM 内存管理器需要驱逐(evict)旧的 BO 来为新的分配腾出空间。 问题:对于 SVM(S…...

Qt程序在麒麟系统发布:除了.desktop文件,你还需要知道的3种打包方案(含AppImage实战)

Qt程序在麒麟系统发布:除了.desktop文件,你还需要知道的3种打包方案(含AppImage实战) 在国产操作系统生态快速发展的今天,银河麒麟(Kylin)系统作为主流国产OS之一,正吸引着越来越多…...

深入剖析 Android 系统属性:从 build.prop 到 Selinux 安全机制

1. Android系统属性基础入门 第一次接触Android系统属性时,我也被各种.prop文件和复杂的配置搞得一头雾水。经过多年实战,我发现理解属性系统其实有个简单的方法 - 把它想象成Windows的注册表。就像注册表存储着Windows的配置信息一样,Androi…...

Linux网络编程核心API速查手册喊

智能体时代的代码范式转移与 C# 的战略转型 传统的 C# 开发模式,即所谓的“工程导向型”开发,要求开发者创建一个复杂的项目结构,包括项目文件(.csproj)、解决方案文件(.sln)、属性设置以及依赖…...

【万字文档+源码】基于springboot与vue海鲜市场系统-计算机项目设计学习

基于springboot与vue海鲜市场系统1.项目简介 管理员的功能是对用户和商家的信息进行监管,使得管理员能够管理用户、商家、海鲜分类等,并可以对这些进行修改和删除等来保证系统的整体运行。 用户的功能有可以去浏览系统首页和商品的信息,查看…...

多租户下的ERP系统的仓储管理模块分析设计轿

springboot自动配置 自动配置了大量组件,配置信息可以在application.properties文件中修改。 当添加了特定的Starter POM后,springboot会根据类路径上的jar包来自动配置bean(比如:springboot发现类路径上的MyBatis相关类&#xff…...