RS485收发器在FPGA中的应用及注意事项

RS485收发器在FPGA中的应用及注意事项

1 前言

明确设计思路,精准定位问题,对于我们后期理解迭代工程有很大的帮助。

这就是我们常说的40%设计,20%编写和剩下的40%时间进行调试优化。

今天为大家带来的是如何解决RS485收发器使能转变引起的毛刺。

2 问题

Q1:什么时候需要用到RS485收发器?

Q2:为何RS485收发器使能转变会引起毛刺?

Q3:如何处理毛刺规避FPGA时序判断?

3 RS485收发器

3.1 硬件基础

3.1.1 标准收发器

RS485收发器是一类集成电路芯片,它的核心作用是在微控制器(如FPGA、MCU)的逻辑电平(如TTL电平,通常是0V/3.3V或0V/5V)与RS485差分信号之间进行双向转换。大多数RS485收发器还具备使能控制引脚(DE或RE),允许主控芯片灵活地切换其工作模式——发送或接收,从而支持半双工通信架构。

在实际应用中,微控制器输出的信号属于低电压、低电流的逻辑电平,适合短距离、高精度的内部电路通信,但无法直接用于长距离传输,容易受到电磁干扰、线路衰减等因素影响,导致信号失真甚至通信失败。

在这里插入图片描述

【差分传输】:RS485标准通过两根信号线(通常标记为A和B,或+和-)之间的电压差来表示数据,具有很强的抑制能力,能够在嘈杂的工业现场稳定工作

【阻抗匹配】:为了保证通信稳定性,通常在总线两端配置120欧姆的终端电阻,以匹配电缆特性阻抗,减少信号反射带来的干扰

【SP3485】:支持485和422,差分电压范围覆盖-7V~12V

3.1.2 自动方向控制收发器

当RS485收发器没有专用的DE(驱动器使能)或RE(接收器使能)控制引脚时,实现半双工通信的核心思路是:采用具备自动方向控制功能的收发器芯片。

这类芯片内部集成了智能逻辑,可以自动管理数据流的方向,如下图右侧:

在这里插入图片描述
特性标准收发器(带DE/RE引脚)自动方向控制收发器(无DE/RE引脚)
控制方式软件手动控制:需要MCU的GPIO引脚和精确的时序代码硬件自动控制:通过检测TXD信号的电平变化自动完成
硬件复杂度较高(需要连接控制线)较低(只需要连接TXD/RXD和电源)
软件复杂度较高(需编程方向切换代码)较低(如同操作普通UART)
可靠性依赖软件时序的正确性由硬件保证,时序更精确可靠
适用场景几乎所有RS485应用,给予开发者完全的控制权引脚资源紧张,追求开发简便性和可靠性的应用

3.2 软件协议

FPGA基于RS485收发器可以实现两大类协议:标准的、广泛应用的通用协议如UART、BissC、EnDat等以及自定义的、为特定应用优化的专用协议。

【BissC、EnDat】:需要两路RS485收发器,一路差分时钟,一路差分数据

4 异常现象

这里以EnDat协议时序进行说明,状态跳转如下:

  1. FPGA进入SEND_ORD状态,主机发送指令
  2. 指令发送后,FPGA进入WAIT状态,等待从机返回高电平起始位
  3. 检测到高电平返回,FPGA进入START_BIT状态
> wavedrom图片

通过时序图和说明可以发现,在等待起始位的WAIT状态中,RXD出现了脉冲周期不符的高电平,而FPGA把这个毛刺当成起始位处理导致状态跳转异常。

5 问题分析

5.1 原因定位

经过复现发现,所使用的RS485收发器在改变EN使能方向时,对应的RXD/TXD会出现高电平毛刺,从而导致FPGA误判。

5.2 解决方案

5.2.1 硬件处理

  • 原理:利用电阻(R)和电容(C)的充放电特性,电容两端的电压不能突变,需要一定的充电时间。一个快速的毛刺脉冲给电容充电时,由于能量小、持续时间短,在电容上的电压还没来得及建立时就消失了,因此输出端看不到明显的电压变化,从而被过滤掉。
  • 优缺点
    • 优点:简单、成本极低、非常有效。
    • 缺点:会延迟信号的正常跳变,RC时间常数(t = R * C)越大,过滤毛刺能力越强,但信号延迟也越严重。因此RC值根据信号频率和毛刺宽度权衡

5.2.2 软件处理

通过观察可以确定,从改变EN使能方向到出现毛刺的时间是固定的,因此可以增加状态延时,以此过滤掉高电平毛刺。

> wavedrom图片

【DELAY】:该状态周期根据毛刺到来时间调整

6 参考

Read more

AI调参技巧:贝叶斯优化Optuna

AI调参技巧:贝叶斯优化Optuna

AI调参技巧:贝叶斯优化Optuna 📝 本章学习目标:本章聚焦性能优化,帮助读者提升模型效率。通过本章学习,你将全面掌握"AI调参技巧:贝叶斯优化Optuna"这一核心主题。 一、引言:为什么这个话题如此重要 在人工智能快速发展的今天,AI调参技巧:贝叶斯优化Optuna已经成为每个AI从业者必须掌握的核心技能。Python作为AI开发的主流语言,其丰富的生态系统和简洁的语法使其成为机器学习和深度学习的首选工具。 1.1 背景与意义 💡 核心认知:Python在AI领域的统治地位并非偶然。其简洁的语法、丰富的库生态、活跃的社区支持,使其成为AI开发的不二之选。掌握Python AI技术栈,是进入AI行业的必经之路。 从NumPy的高效数组运算,到TensorFlow和PyTorch的深度学习框架,Python已经构建了完整的AI开发生态。据统计,超过90%的AI项目使用Python作为主要开发语言,AI岗位的招聘要求中Python几乎是标配。 1.2 本章结构概览 为了帮助读者系统性地掌握本章内容,我将从以下几个维度展开: 📊 概念解析 → 原理推导 → 代

Flutter 组件 genkit 的适配 鸿蒙Harmony 实战 - 驾驭大模型开发套件、实现鸿蒙端 AI 智能流式响应与提示词工程自动化方案

Flutter 组件 genkit 的适配 鸿蒙Harmony 实战 - 驾驭大模型开发套件、实现鸿蒙端 AI 智能流式响应与提示词工程自动化方案

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 组件 genkit 的适配 鸿蒙Harmony 实战 - 驾驭大模型开发套件、实现鸿蒙端 AI 智能流式响应与提示词工程自动化方案 前言 在鸿蒙(OpenHarmony)生态向智能化、全场景自动化的演进过程中,“生成式 AI(Generative AI)”不再仅仅是一个噱头,而是重塑应用交互逻辑的核心底座。面对日益复杂的 LLM(大语言模型)调用链路、层出不穷的提示词(Prompt)版本管理以及对实时流式响应(Streaming)的严苛要求。如果仅仅依靠原始的 HTTP POST 请求。那么不仅会导致开发效率极低。更难以应对 AI 业务中常见的“幻觉审计”与“多模型动态切换”等高阶挑战方案。 我们需要一种“开发者友好、

AI大模型微调(三)------Qwen3模型Lora微调(使用Llamafactory)

AI大模型微调(三)------Qwen3模型Lora微调(使用Llamafactory)

AI大模型微调(三)------Qwen3模型Lora微调(使用Llamafactory) 文章目录 * AI大模型微调(三)------Qwen3模型Lora微调(使用Llamafactory) * 一、安装LLaMA-Factory&开发环境 * 二、数据集 * 1.Alpaca * 2.ShareGPT * 3.自定义数据集 * 三、LoRA指令微调 * 四、可视化/零代码微调 * 1.模型下载源 * 2.微调方法 * 3.Train-数据集 * 4.Train-计算类型 * 5.模型名称 * 6.导出微调过的模型 * 五、可能出现的问题 * 1.CUDA未找到 * 2.ValueError: Your setup doesn't support bf16/

论文AI率太高?八个方法教你30分钟降低AIGC,90%到2.4%亲测有效!

现在写论文的人越来越多,一写就会出现AI率过高的问题,特别是在研究生论文中,使用AI辅助写作已经非常普遍了,但是只要查重一下就会“凉了”,导师直接打回去说AI味太浓,没有自己的想法。 去年我自己也犯过同样的错误,初稿的时候AI率是66%,查重35%,导师说我全是机器的味道,那时候真的很难受。 经过一周的努力之后,一边手动修改一边测试各种工具,最后将AI率从90%以上降到了2.4%,顺利提交并通过了。 今天就来分享一下效果比较好的8个实用方法,在三十分钟内就可以把AI率降低到可以接受的程度,不管是论文、报告还是文案都可以轻松摆脱AI腔。 降AI率的核心是什么? 降AI不是简单的换词,而是去除机器的痕迹,保留主要信息。 很多人以为降低AI率就是用同义词替换,但是结果反而变得很奇怪,专业性也不强了。 其实是在打破AI所固有的模式:固定的句式、过于严谨的逻辑、表达含糊不清没有实质内容。 不用这些套路的话,AI率就会下降,学术上的严谨性也不会受到影响。 方法一:变换语态,长短句交替使用 AI经常使用被动语态以及较长的句子,如“实验数据经过分析后得到的结果”,显得很机械。短