×

Layout工程师的强迫症:绕线方式的坑资料下载

消耗积分:0 | 格式:pdf | 大小:114.21KB | 2021-03-31

王毅山

分享资料个

从小学二年级开始我们就学习了如何判断一个人有没有强迫症,比如看见一个程序猿不管是打字还是写代码,括号总是一对一起敲,那他肯定是个强迫症患者。对于Layout工程师来说有没有强迫症,就看等长绕得怎么样。 比如下面这位同学,深得等长精髓: 5mil从来不是问题���0mil只是时间问题。 不可否认对于很多工程师来说,绕等长也是画板的乐趣之一。也一直流传着这样一句话:没有绕不出来的等长,只是你不想加班。 那么把等长误差做到5mil,2mil甚至1mil就可以不加班了吗? 想什么呢,不加班怎么有鸡腿吃。 对于等长来说,从来都不在乎这几个mil误差,1PS的时间信号就能传输大约6mil,想想你的系统真的缺这1ps吗? 既然不缺,那么等长的目的是什么呢? 等长从来都不是目的,等延时才是目的。 接收端并不关心这些信号经历了多少微带线,走过了多少带状线,翻过了多少过孔,又在连接器上浪费了多少时间。它只关心,这个信号和它的小伙伴出现在家门口的时候是不是整整齐齐。 既然如此那各种规则中等长误差5mil,25mil这些的规则的由来是什么? 之所以制定这些规则,是因为长度这个概念更容易被接受。如果规则给出的约束是5ps,实际操作者不清楚信号的传播速度就会一脸懵逼,而给出30mil这个直观概念,大家一下都清楚了。虽然不科学,但可行。 道理都懂了,但是这里面还是有一些坑,接下来我们将用至少三期的内容来介绍如何科学绕等长,科学避免加班改板子。 这一期先来看第一个坑:绕线方式 常见的绕线方式有Accordion,Trombone以及Sawtooh。俗话说不会做木工的音乐家一定不是一个优秀的EDA软件的工程师。Cadence的工程师自认为自己是优秀的,因此这几种绕线方式分别命名为手风琴、长号、锯齿。当然我们更习惯的称呼有长城、大波浪、小波浪等等...... 锯齿的绕线方式,通常适用于细微的调整,因此主要分析手风琴和长号(文艺一下)这两种方式。 这次试验的DEMO板,一共画了4条走线,第一条走线的等长GAP设置得特别大,约等于没有绕等长;第二个等长方式是长号;第三个是GAP间距正常的手风琴;第四个是GAP间距较小的手风琴。 4组实验,走线长度完全相等,公平公正。 我们要分析4个信号是否同时到达接收端,因此我们需要发送端、接收端、以及无源通道。既然需要无源通道,那么老规矩,提取S参数吧。 简单点,这次我们用SIWAVE,快速仿真抽取4条走线的S参数。 将S参数导出保存,现在我们开始分析。搭建分析威廉希尔官方网站 : 威廉希尔官方网站 的原理是通过信号源同时输出阶跃信号,然后检查信号在接收端达到某个电压幅值时的时间,以此来判断信号是否同时到达。 一切就绪,仿真: 结果就非常的interesting了,虽然四个走线长度完全相同,但是它们到达末端的时间却完全不一致。我们的冠军和最后一名的差距达到了21.7PS,按照1PS大约6mil换算下来,实际等长误差约达到了130mil,这可比苦心积虑绕线去纠结几个十来个Mil大多了。 进一步分析结果,信号最早到达的是我们GAP小间距手风琴,其次是正常GAP间距的手风琴,再者是长号,最后是我们的正常走线。 结果已经清晰了。而造成这个结果的罪魁祸首,就是自耦合。 当信号在蛇形线上传输的时候,信号还在传输线的这一头,但能量已经有一部分耦合到了平行线的另一头,于是当这个信号和自耦合叠加在一起,信号就提前到达。 GAP间距越小耦合也就越严重,信号自然到的更早。 如果要避免这种现象的产生,让等长真正等长,可以通过减小波浪的数量以及增加波浪的GAP间距来进行优化。 这是第一个坑,坑还有很多,下期我们接着分析。 本文转载自: PCB设计与信号完整性仿真(作者:十四岁的十四 ) 免责声明:本文为转载文章,转载此文目的在于传递更多信息,版权归原作者所有。本文所用视频、图片、文字如涉及作品版权问题,请联系小编进行处理。 (mbbeetchina)

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

评论(0)
发评论

下载排行榜

全部0条评论

快来发表一下你的评论吧 !

'+ '

'+ '

'+ ''+ '
'+ ''+ ''+ '
'+ ''+ '' ); $.get('/article/vipdownload/aid/'+webid,function(data){ if(data.code ==5){ $(pop_this).attr('href',"/login/index.html"); return false } if(data.code == 2){ //跳转到VIP升级页面 window.location.href="//m.obk20.com/vip/index?aid=" + webid return false } //是会员 if (data.code > 0) { $('body').append(htmlSetNormalDownload); var getWidth=$("#poplayer").width(); $("#poplayer").css("margin-left","-"+getWidth/2+"px"); $('#tips').html(data.msg) $('.download_confirm').click(function(){ $('#dialog').remove(); }) } else { var down_url = $('#vipdownload').attr('data-url'); isBindAnalysisForm(pop_this, down_url, 1) } }); }); //是否开通VIP $.get('/article/vipdownload/aid/'+webid,function(data){ if(data.code == 2 || data.code ==5){ //跳转到VIP升级页面 $('#vipdownload>span').text("开通VIP 免费下载") return false }else{ // 待续费 if(data.code == 3) { vipExpiredInfo.ifVipExpired = true vipExpiredInfo.vipExpiredDate = data.data.endoftime } $('#vipdownload .icon-vip-tips').remove() $('#vipdownload>span').text("VIP免积分下载") } }); }).on("click",".download_cancel",function(){ $('#dialog').remove(); }) var setWeixinShare={};//定义默认的微信分享信息,页面如果要自定义分享,直接更改此变量即可 if(window.navigator.userAgent.toLowerCase().match(/MicroMessenger/i) == 'micromessenger'){ var d={ title:'Layout工程师的强迫症:绕线方式的坑资料下载',//标题 desc:$('[name=description]').attr("content"), //描述 imgUrl:'https://'+location.host+'/static/images/ele-logo.png',// 分享图标,默认是logo link:'',//链接 type:'',// 分享类型,music、video或link,不填默认为link dataUrl:'',//如果type是music或video,则要提供数据链接,默认为空 success:'', // 用户确认分享后执行的回调函数 cancel:''// 用户取消分享后执行的回调函数 } setWeixinShare=$.extend(d,setWeixinShare); $.ajax({ url:"//www.obk20.com/app/wechat/index.php?s=Home/ShareConfig/index", data:"share_url="+encodeURIComponent(location.href)+"&format=jsonp&domain=m", type:'get', dataType:'jsonp', success:function(res){ if(res.status!="successed"){ return false; } $.getScript('https://res.wx.qq.com/open/js/jweixin-1.0.0.js',function(result,status){ if(status!="success"){ return false; } var getWxCfg=res.data; wx.config({ //debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。 appId:getWxCfg.appId, // 必填,公众号的唯一标识 timestamp:getWxCfg.timestamp, // 必填,生成签名的时间戳 nonceStr:getWxCfg.nonceStr, // 必填,生成签名的随机串 signature:getWxCfg.signature,// 必填,签名,见附录1 jsApiList:['onMenuShareTimeline','onMenuShareAppMessage','onMenuShareQQ','onMenuShareWeibo','onMenuShareQZone'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2 }); wx.ready(function(){ //获取“分享到朋友圈”按钮点击状态及自定义分享内容接口 wx.onMenuShareTimeline({ title: setWeixinShare.title, // 分享标题 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享给朋友”按钮点击状态及自定义分享内容接口 wx.onMenuShareAppMessage({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 type: setWeixinShare.type, // 分享类型,music、video或link,不填默认为link dataUrl: setWeixinShare.dataUrl, // 如果type是music或video,则要提供数据链接,默认为空 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到QQ”按钮点击状态及自定义分享内容接口 wx.onMenuShareQQ({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口 wx.onMenuShareWeibo({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到QQ空间”按钮点击状态及自定义分享内容接口 wx.onMenuShareQZone({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); }); }); } }); } function openX_ad(posterid, htmlid, width, height) { if ($(htmlid).length > 0) { var randomnumber = Math.random(); var now_url = encodeURIComponent(window.location.href); var ga = document.createElement('iframe'); ga.src = 'https://www1.elecfans.com/www/delivery/myafr.php?target=_blank&cb=' + randomnumber + '&zoneid=' + posterid+'&prefer='+now_url; ga.width = width; ga.height = height; ga.frameBorder = 0; ga.scrolling = 'no'; var s = $(htmlid).append(ga); } } openX_ad(828, '#berry-300', 300, 250);