元器件焊盘的PCB处理方式分析与总结

2024-02-18 05:36

本文主要是介绍元器件焊盘的PCB处理方式分析与总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        对于高速信号走线的特性阻抗,都需要按照实际要求进行精度控制,所以,任何因设计因素带来的阻抗波动都应该进行优化,如下图所示,为一个12层板设计中的50Ω微带走线,需要在走线之上放置电感;

        但是,电感焊盘的使用,导致在原有叠构下,不能保证信号线50Ω阻抗设计要求,因此,需要进行layout设计优化;

        控制Pad阻抗的有效办法,是挖空其正下方的金属参考面,如下图所示,通过控制挖空区域的宽度以及层数,达到有效控制阻抗的目的,结合上一张图中的Wp与下图中的Wg,定义了比例值ratio,用于设计优化的尺寸比例控制;

        通过下图的仔细对比,可以发现,控制pad阻抗的一般规律:

       1.  挖空区域的宽度Wg≥1.75*Wp宽度为宜,当然并非绝对的, ratio值具体要视pad的尺寸、设计的叠构和信号要求(tr)而定;

        2. 控制挖空宽度的同时,调整挖空参考面的层数是另一个有效的方式,但是,需要注意,参考面间的介质厚度,如果介质厚度很薄,同时挖空相邻两层参考面会效果显著,反之,则没有必要,同样需要视具体设计而定。

        虽然主要关注的是信号线上pad的阻抗控制情况,但对于电感封装中相邻pad间敷铜的处理,同样会影响到之前的阻抗控制结果,如下图所示,即需要控制电感封装焊盘之间预留参考层的宽度--Wdelta

        仿真结果表明,相邻pad之间的参考面会直接影响阻抗:

        1. 如蓝色线所示,直接整体挖空参考面是不可取的;

        2. 需要配合前述仿真得到的挖空区域宽度进行设计考虑--ratio取值越大,Wdelta就会越小,layout的铺设铜操作难度加大,具体值的选取,建议在具体的应用中进行单独的评估。

        控制Wdelta的宽度,对于S12的影响,与ratio配合使用,可以达到很好的效果:

        控制Wdelta的宽度,对于S11的影响,与ratio配合使用,可以达到很好的效果:

        上述仿真结果,再结合加工工艺的能力,Wdelta=0.2mm是较为合适的。        

        另一个在实际中经常出现的设计因素,就是stub,这个当然是要避免使用,基本是一个默认的设计规避规则:

        如上图所示,假设Lstub=0.5mm,可以发现其对阻抗的影响显著:

        假设Lstub=0.5mm,可以发现其对S11的影响显著:

        假设Lstub=0.5mm,可以发现其对S12的影响显著:

        通过上述的仿真分析,将控制pad阻抗的方法总结如下:

        1. 避免在信号线上使用stub

        2. 控制大尺寸pad阻抗的有效方法是:挖空参考面,如果pad宽度大于走线宽度,从挖空相邻层参考面开始进行优化,但需要通过仿真确定ratio值,本例中可取值1.75;

        3. 避免整体挖空封装的参考面,尤其是大尺寸的封装,对于Wdelta值的选取,需要按照实际设计情况单独仿真得到,本例中可取值0.2;

        除此之外,还需要避免使用过孔。

以上都是基于一级器件(直接与信号线相连)的设计考虑,对于后级的器件,没有这些要求,但是,建议紧凑布局,整体挖空,如下图所示;

        以上,在Murata的仿真报告中均有体现,并且,仿真结果显示均一致。

        参考文献:

        (E)APS-407_Board_design_and_Inductor_s_layout_about_Bias-T_circuit_for_PoC

这篇关于元器件焊盘的PCB处理方式分析与总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/720200

相关文章

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

gradle第三方Jar包依赖统一管理方式

《gradle第三方Jar包依赖统一管理方式》:本文主要介绍gradle第三方Jar包依赖统一管理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景实现1.顶层模块build.gradle添加依赖管理插件2.顶层模块build.gradle添加所有管理依赖包

Linux之systemV共享内存方式

《Linux之systemV共享内存方式》:本文主要介绍Linux之systemV共享内存方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、工作原理二、系统调用接口1、申请共享内存(一)key的获取(二)共享内存的申请2、将共享内存段连接到进程地址空间3、将

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

Python中的Walrus运算符分析示例详解

《Python中的Walrus运算符分析示例详解》Python中的Walrus运算符(:=)是Python3.8引入的一个新特性,允许在表达式中同时赋值和返回值,它的核心作用是减少重复计算,提升代码简... 目录1. 在循环中避免重复计算2. 在条件判断中同时赋值变量3. 在列表推导式或字典推导式中简化逻辑

python处理带有时区的日期和时间数据

《python处理带有时区的日期和时间数据》这篇文章主要为大家详细介绍了如何在Python中使用pytz库处理时区信息,包括获取当前UTC时间,转换为特定时区等,有需要的小伙伴可以参考一下... 目录时区基本信息python datetime使用timezonepandas处理时区数据知识延展时区基本信息

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式