CN113966084A - 坐标文件和Gerber文件中焊盘的自动对位方法 - Google Patents
坐标文件和Gerber文件中焊盘的自动对位方法 Download PDFInfo
- Publication number
- CN113966084A CN113966084A CN202111273882.5A CN202111273882A CN113966084A CN 113966084 A CN113966084 A CN 113966084A CN 202111273882 A CN202111273882 A CN 202111273882A CN 113966084 A CN113966084 A CN 113966084A
- Authority
- CN
- China
- Prior art keywords
- coordinate
- pads
- pad
- file
- layer
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
- 238000000034 method Methods 0.000 title claims abstract description 31
- 238000012545 processing Methods 0.000 claims abstract description 12
- 238000007781 pre-processing Methods 0.000 claims abstract description 7
- 238000012795 verification Methods 0.000 claims description 10
- 239000013598 vector Substances 0.000 claims description 9
- RYGMFSIKBFXOCR-UHFFFAOYSA-N Copper Chemical compound [Cu] RYGMFSIKBFXOCR-UHFFFAOYSA-N 0.000 claims description 7
- 229910052802 copper Inorganic materials 0.000 claims description 7
- 239000010949 copper Substances 0.000 claims description 7
- 238000003012 network analysis Methods 0.000 claims description 4
- 238000003466 welding Methods 0.000 claims description 4
- 230000009977 dual effect Effects 0.000 claims description 3
- 238000012216 screening Methods 0.000 claims description 3
- 238000004519 manufacturing process Methods 0.000 abstract description 13
- 238000013461 design Methods 0.000 abstract description 8
- 238000007650 screen-printing Methods 0.000 description 4
- 230000008569 process Effects 0.000 description 3
- 238000004458 analytical method Methods 0.000 description 2
- 239000000463 material Substances 0.000 description 2
- 238000004364 calculation method Methods 0.000 description 1
- 230000001419 dependent effect Effects 0.000 description 1
- 238000000605 extraction Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000004806 packaging method and process Methods 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 238000012163 sequencing technique Methods 0.000 description 1
- 230000009466 transformation Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H05—ELECTRIC TECHNIQUES NOT OTHERWISE PROVIDED FOR
- H05K—PRINTED CIRCUITS; CASINGS OR CONSTRUCTIONAL DETAILS OF ELECTRIC APPARATUS; MANUFACTURE OF ASSEMBLAGES OF ELECTRICAL COMPONENTS
- H05K3/00—Apparatus or processes for manufacturing printed circuits
- H05K3/0008—Apparatus or processes for manufacturing printed circuits for aligning or positioning of tools relative to the circuit board
-
- H—ELECTRICITY
- H05—ELECTRIC TECHNIQUES NOT OTHERWISE PROVIDED FOR
- H05K—PRINTED CIRCUITS; CASINGS OR CONSTRUCTIONAL DETAILS OF ELECTRIC APPARATUS; MANUFACTURE OF ASSEMBLAGES OF ELECTRICAL COMPONENTS
- H05K3/00—Apparatus or processes for manufacturing printed circuits
- H05K3/0005—Apparatus or processes for manufacturing printed circuits for designing circuits by computer
-
- H—ELECTRICITY
- H05—ELECTRIC TECHNIQUES NOT OTHERWISE PROVIDED FOR
- H05K—PRINTED CIRCUITS; CASINGS OR CONSTRUCTIONAL DETAILS OF ELECTRIC APPARATUS; MANUFACTURE OF ASSEMBLAGES OF ELECTRICAL COMPONENTS
- H05K3/00—Apparatus or processes for manufacturing printed circuits
- H05K3/30—Assembling printed circuits with electric components, e.g. with resistor
- H05K3/32—Assembling printed circuits with electric components, e.g. with resistor electrically connecting electric components or wires to printed circuits
- H05K3/34—Assembling printed circuits with electric components, e.g. with resistor electrically connecting electric components or wires to printed circuits by soldering
Landscapes
- Engineering & Computer Science (AREA)
- Manufacturing & Machinery (AREA)
- Microelectronics & Electronic Packaging (AREA)
- Computer Hardware Design (AREA)
- Design And Manufacture Of Integrated Circuits (AREA)
Abstract
本发明涉及SMT生产加工技术领域,特别涉及坐标文件和Gerber文件中焊盘的自动对位方法,包括步骤S1,对Gerber文件进行预处理;步骤S2,创建虚拟元器件;步骤S3,虚拟元器件与坐标文件进行对位;步骤S4,坐标文件与虚拟元器件对位校验;步骤S5,坐标核对与调整。与现有技术相比,本发明的坐标文件和Gerber文件中焊盘的自动对位方法通用性强、能够快速的自动对位,提高设计效率及加工效率,确保生产质量,降低生产品质风险。
Description
【技术领域】
本发明涉及SMT生产加工技术领域,特别涉及坐标文件和Gerber文件中焊盘的自动对位方法。
【背景技术】
SMT加工中,一般是使用PCB的生产Gerber作为原始资料,而在PCB生产过程中,有可能对Gerber文件进行SET拼版、重定坐标原点、整体旋转、整体镜像等操作,导致做SMT时,坐标文件与Gerber文件存在整体变换的情况,SMT工程人员需要花费较大的精力去整体对位。
在PCB设计阶段,每个PCB设计工程师的设计习惯不同,在设计PCB封装库时设定的坐标原点位置各有差异。从而导出的坐标文件,坐标点与焊盘的相对位置可能不同。而SMT工厂在加工时统一以元器件中心位置作为贴片程序的坐标。这就会导致客户提供的坐标文件不能直接当做SMT贴片程序的坐标。
在SMT加工过程中,需要确保贴片程序中的每个元器件的坐标位置都正确,否则可能贴偏造成生产报废。如上所述,客户提供的坐标文件不能直接当做SMT贴片程序的坐标,需要核对正确,方能进行生产。
目前行业内普遍的核对做法是逐个坐标点人工核对,核对步骤如下:
1.将Gerber文件与坐标文件导入图形软件中,并利用坐标文件生成虚拟元器件层,同时将坐标文件与BOM文件合并;
2.整体检查坐标器件层与Gerber文件焊盘是否对齐,如不对齐,手动操作,整体旋转、镜像、平移坐标器件层等操作,使之与Gerber文件对齐;
3.逐个切换每个器件坐标位置,核对坐标位置是否准确。
但是近年来,PCB板设计复杂度也在大大提升,使用元器件种类和数量也越来越多,特别是产品越来越向多品种、小批量方向发展,贴片厂订单数量越来越多,工程师核对坐标工作量越来越大。这种传统的核对坐标模式非常依赖于工程师的经验,同时容易遗漏,造成生产品质风险。
【发明内容】
为了克服上述问题,本发明提出一种可有效解决上述问题的坐标文件和Gerber文件中焊盘的自动对位方法。
本发明解决上述技术问题提供的一种技术方案是:提供一种坐标文件和Gerber文件中焊盘的自动对位方法,包括如下步骤:
步骤S1,对Gerber文件进行预处理;
步骤S2,创建虚拟元器件;
步骤S3,虚拟元器件与坐标文件进行对位;
步骤S4,坐标文件与虚拟元器件对位校验;
步骤S5,坐标核对与调整。
优选地,所述步骤S2中,参照Gerber文件中的字符层和焊盘层的位置关系,创建虚拟元器件,当字符层和焊盘层符合预设情况,认为当前搜索到的焊盘组成一个元器件,利用这些焊盘创建虚拟元器件对象,将虚拟元器件添加到虚拟元器件数组中。
优选地,所述步骤S2包括如下步骤:
步骤SA1,将字符层元素抽网络分析;
步骤SA2,遍历字符层中每个网络,在当前网络极限矩形范围内,搜索与字符接触的焊盘,如果搜索到的焊盘数低于2个,则不符合当前预设;
步骤SA3,将步骤SA2中的焊盘组极限矩形与字符层当前网络的极限矩形对比,当两者的中心距离不超过焊盘组的长或宽的75%,则判断为有效焊盘组,利用该焊盘组创建虚拟元器件,并添加到虚拟元器件数组。
优选地,所述步骤S2包括如下步骤:
步骤SB1,确定搜索矩形;
步骤SB2,在搜索矩形范围内,搜索焊盘层与搜索矩形接触的焊盘;
步骤SB3,当搜索到的焊盘数量为2,且两焊盘为水平或垂直关系时,筛选出满足贴片焊盘特征的焊盘创建虚拟元器件,并添加到虚拟元器件数组。
优选地,所述步骤S2包括如下步骤:
步骤SC1,遍历未组成有效焊盘组的方形焊盘,将该焊盘加入队列并标记未搜索状态,以第一矩形为搜索范围,搜索周围焊盘;
步骤SC2,如果步骤SC1中搜索到的焊盘没有搜索标记,则将所有搜索到的焊盘添加到待搜索队列;
步骤SC3,将待搜索队列中的种子焊盘删除,以下一个待搜索焊盘为种子焊盘,重复步骤SC1,直到待搜索队列中焊盘数量为零;
步骤SC4,当前搜索到两个焊盘,且焊盘大小误差小于0.1,呈水平或垂直分布,两焊盘距离在0.2到1.0之间,判断搜索到。
优选地,所述步骤S3包括如下步骤:
步骤S31,创建虚拟元器件的器件数组zrComp数组,将pin角数量为2的虚拟元器件放到zrComp数组里面;
步骤S32,对zrComp数组的虚拟元器件进行排序,将每个虚拟元器件的中心坐标x与y相加得到坐标之和,按坐标之和从小到大的顺序排列虚拟元器件;
步骤S33,创建一个虚拟坐标层,将坐标文件的对象复制到虚拟坐标层;
步骤S34,将虚拟坐标层的元素按照中心坐标x与y相加得到坐标之和,坐标之和从小到大的顺序排列;
步骤S35,遍历虚拟元器件的元素,将虚拟元器件的当前元素与当前后的所有元素的中心坐标组成向量,将这些向量放到veclist数组里;
步骤S36,遍历坐标文件,样本找的次数超过了总数的20%就跳过;
步骤S37,遍历veclist数组,将当前的坐标与veclist数组的每一个向量相加,得到新的坐标点,在坐标层搜索到器件,记录搜索到和没搜索到的数量,如果搜索到的数量在90%以上,或者5个以上至少搜索到80%,则找到坐标偏移值;
步骤S38,对虚拟坐标层的每个元素按坐标偏移值偏移,对位成功;
步骤S39,如果对位不成功,虚拟坐标层分别旋转90度、180度、270度、X轴镜像、Y轴镜像,重复步骤S34到步骤S38进行对位,直到对位成功。
优选地,所述步骤S4包括如下步骤:
步骤S41,遍历坐标层下所有器件,通过器件的位号与bom信息,在元件库中获取元件库模型信息;
步骤S42,在坐标点上将获取到的元件库以坐标位置为中心放置,以元件库的每个引脚为搜索区域,在焊盘层搜索焊盘;
步骤S43,如果搜索到焊盘,当引脚与焊盘接触的面积超过元件引脚面积的70%,视为引脚与焊盘匹配;当所有引脚都匹配到焊盘,即为元件库匹配到焊盘;
步骤S44,如果未匹配到,元件库分别按照90°、180°、270°进行旋转,重复步骤S42,直到匹配为止;
步骤S45,步骤S44中匹配成功,记为true,匹配不成功,记为false,当成功数量超过总数量80%以上,认为虚拟元器件校验成功,否则校验失败,重复步骤S3。
优选地,所述步骤S5包括如下步骤:
步骤S51,遍历坐标层中的坐标元素,获取关联的焊盘,获取所有关联的焊盘极限矩形,计算极限矩形的中心点和坐标值的距离;
步骤S51,如果上述步骤S51中距离偏差在0.2mm以内,记录该坐标核对正确,并将坐标值调整至焊盘极限矩形的中心。
优选地,所述步骤S1中,对Gerber文件的预处理包括如下两种情形:
情形a,Gerber文件焊盘层存在线弧元素填充的焊盘,将这些线弧元素做铜皮化处理,转成surface;
情形b,Gerber文件是拼版文件,将Gerber文件中字符层和焊盘层处理成单pcs。
优选地,所述步骤S2中,包括如下三种情形;
情形A,焊盘与字符元素接触;情形B,成对焊盘与字符存在特定位置关系;情形C,根据焊盘层找成对的双焊盘器件。
与现有技术相比,本发明的坐标文件和Gerber文件中焊盘的自动对位方法解决了目前在PCB生成坐标文件,存在位置偏差时,导致效率和质量低,以及处理耗费人力过多的问题,取得了通用性强、能够快速的自动对位,提高设计效率及加工效率,确保生产质量,降低生产品质风险。
【附图说明】
图1为本发明坐标文件和Gerber文件中焊盘的自动对位方法的整体步骤流程图;
图2为本发明坐标文件和Gerber文件中焊盘的自动对位方法的步骤S3具体流程图;
图3为本发明坐标文件和Gerber文件中焊盘的自动对位方法的步骤S4具体流程图;
图4为本发明坐标文件和Gerber文件中焊盘的自动对位方法的步骤S5具体流程图。
【具体实施方式】
为了使本发明的目的、技术方案及优点更加清楚明白,以下结合附图及实施实例,对本发明进行进一步详细说明。应当理解,此处所描述的具体实施例仅用于解释本发明,并不用于限定本发明。
需要说明,本发明实施例中所有方向性指示(诸如上、下、左、右、前、后……)仅限于指定视图上的相对位置,而非绝对位置。
另外,在本发明中如涉及“第一”、“第二”等的描述仅用于描述目的,而不能理解为指示或暗示其相对重要性或者隐含指明所指示的技术特征的数量。由此,限定有“第一”、“第二”的特征可以明示或者隐含地包括至少一个该特征。在本发明的描述中,“多个”的含义是至少两个,例如两个,三个等,除非另有明确具体的限定。
请参阅图1至图4,本发明的坐标文件和Gerber文件中焊盘的自动对位方法,包括如下步骤:
步骤S1,对Gerber文件进行预处理。
所述步骤S1中,对Gerber文件的预处理包括如下两种情形。
情形a,Gerber文件焊盘层存在线弧元素(线段和圆弧)填充的焊盘,将这些线弧元素做铜皮化处理,转成surface。具体包括如下步骤:
步骤Sa1,将焊盘层中所有元素抽网络分析;
步骤Sa2,遍历步骤Sa1分析后的所有网络,如果组成该网络的线弧元素数量大于等于1,将当前网络的所有元素做布尔运算求并,即铜皮化处理,得到一个surface;
步骤Sa3,删除铜皮化前的原始元素,将铜皮化后的surface添加到焊盘层中。
情形b,Gerber文件是拼版文件,将Gerber文件中字符层和焊盘层处理成单pcs。具体包括如下步骤:
步骤Sb1,找到PCB板的外形线,将外形线元素抽网络分析;
步骤Sb2,获取步骤Sb1分析结果中极限矩形最大的网络,取其所有元素;
步骤Sb3,将步骤Sb2中所有元素做铜皮化处理,得到一个island(外环)和若干个hole(内环)的surface结构;
步骤Sb4,将步骤Sb3中所有内环,按从左到右、从下到上排序,遍历排序后的内环,判断当前内环是否为PCB板单pcs;判断方法为,分别以内环为边界范围,在焊盘层搜索被内环包含的焊盘元素,统计被包含的焊盘元素个数,焊盘数量最多的若干个内环为PCB板单pcs;
步骤Sb5,将步骤Sb4中找到的PCB板单pcs,取左下角;
步骤Sb6,使用步骤Sb5中左下角的内环为边界范围,从焊盘层中搜索所有被内环包含的焊盘元素,将这些焊盘元素复制出来,作为新的焊盘层;
步骤Sb7,使用步骤Sb5中左下角的内环为边界范围,从字符层中搜索所有被内环包含的字符元素,将这些字符元素复制出来,作为新的字符层。
特别说明:坐标文件与Gerber文件可能存在不对齐情况,产生不对齐其原因有以下两点:1、客户提供的Gerber文件大部分是PCB CAM工程处理过后的Gerber,其坐标原点和原始PCB的坐标可能存在偏移;2、从EDA设计软件中导出坐标文件和Gerber的文件,参考原点、坐标变换方式(如旋转角度、镜像)设置可能不一样,导致导出的坐标文件和Gerber存在旋转、镜像和偏移的情况。
步骤S2,创建虚拟元器件。
所述步骤S2中,参照Gerber文件中的字符层和焊盘层的位置关系,创建虚拟元器件,当字符层和焊盘层符合预设情况,认为当前搜索到的焊盘组成一个元器件,利用这些焊盘创建虚拟元器件对象,将虚拟元器件添加到虚拟元器件数组中。
所述步骤S2中,包括如下三种情形。
情形A,焊盘与字符元素接触,创建虚拟元器件包括如下步骤:
步骤SA1,将字符层元素抽网络分析;
步骤SA2,遍历字符层中每个网络,在当前网络极限矩形范围内,搜索与字符接触的焊盘,如果搜索到的焊盘数低于2个,则不符合当前预设;
步骤SA3,将步骤SA2中的焊盘组极限矩形与字符层当前网络的极限矩形对比,当两者的中心距离不超过焊盘组的长或宽的75%,则判断为有效焊盘组,利用该焊盘组创建虚拟元器件,并添加到虚拟元器件数组;
步骤SA4,将当前丝印网络标号标记下来,表示该网络已经创建了虚拟元器件。
情形B,成对焊盘与字符存在特定位置关系,利用这两焊盘,创建虚拟元器件,并添加到虚拟元器件数组中。所述特定位置关系包括如下几种:
关系一、丝印为单条短线段,两焊盘对称分布在这条短线段两侧;
关系二、丝印为两条相隔较近的短线段,两焊盘对称分布在这两条短线段中间或者两侧;
关系三、丝印为“中括号”形状,两焊盘分布在中括号内;
关系四、丝印为“矩形框”形状,两焊盘分布在矩形框内。
在丝印上搜索满足以上任意一种特定位置关系的情况,遍历丝印层中每个网络,排除已经提取过虚拟元器件封装的网络,满足以下四种情况,即为有效焊盘。
在情形B中,创建虚拟元器件包括如下步骤:
步骤SB1,确定搜索矩形;
步骤SB2,在搜索矩形范围内,搜索焊盘层与搜索矩形接触的焊盘;
步骤SB3,当搜索到的焊盘数量为2,且两焊盘为水平或垂直关系时,筛选出满足贴片焊盘特征的焊盘创建虚拟元器件,并添加到虚拟元器件数组。
所述步骤SB1中,确定搜索矩形时分别对应上述四种特定位置关系,包括如下步骤:
步骤SB11,搜索一条独立的线段,该线段需满足如下条件:水平或垂直线段,长度范围(0.2,2.5),宽度范围(0.05,0.5);以当前线段的极限矩形为基准,如果线段为水平,分别向上、下扩展第一阈值范围;如果线段为垂直,分别向左、右扩展第一阈值范围,得到搜索矩形。此步骤对应关系一。
步骤SB12,搜索两条成对的线段,这两条线段需满足如下条件:水平或者垂直线段,长度范围(0.2,2.5),宽度范围(0.05,0.5),且满足两条线段等长、等宽、平行、距离范围(0.2,2.5);以当前两条线段的极限矩形为基准,如果线段为水平,分别向上、下扩展第一阈值范围;如果线段为垂直,分别向左、右扩展第一阈值范围,得到搜索矩形。此步骤对应关系二。
步骤SB13,搜索一组近似“中括号[]”布局的字符网络,满足每半边由3条线段组成,整组“中括号[]”极限矩形长度范围(0.5,2.5),宽度范围(0.3,1.0),并以整组“中括号[]”极限矩形为搜索矩形。此步骤对应关系三。
步骤SB14,搜索“矩形框”布局的字符网络,满足由四条首尾相连的线段组成,整个“矩形框”的极限矩形长度范围(0.5,2.5),宽度范围(0.3,1.0),并以整个“矩形框”的极限矩形为搜索矩形。此步骤对应关系四。
情形C,根据焊盘层找成对的双焊盘器件,包括如下步骤:
步骤SC1,遍历未组成有效焊盘组的方形焊盘,将该焊盘加入队列并标记未搜索状态,以第一矩形(长2.5mm、宽2.5mm)为搜索范围,搜索周围焊盘;
步骤SC2,如果步骤SC1中搜索到的焊盘没有搜索标记,则将所有搜索到的焊盘添加到待搜索队列;
步骤SC3,将待搜索队列中的种子焊盘删除,以下一个待搜索焊盘为种子焊盘,重复步骤SC1,直到待搜索队列中焊盘数量为零;
步骤SC4,当前搜索到两个焊盘,且焊盘大小误差小于0.1,呈水平或垂直分布,两焊盘距离在0.2到1.0之间,判断搜索到。
步骤S3,虚拟元器件与坐标文件进行对位。
所述步骤S3包括如下步骤:
步骤S31,创建虚拟元器件的器件数组zrComp数组,将pin角数量为2的虚拟元器件放到zrComp数组里面,zrComp数组的虚拟元器件数量3个以下则不自动对位;
步骤S32,对zrComp数组的虚拟元器件进行排序,将每个虚拟元器件的中心坐标x与y相加得到坐标之和,按坐标之和从小到大的顺序排列虚拟元器件;
步骤S33,创建一个虚拟坐标层,将坐标文件的对象复制到虚拟坐标层,方便计算;
步骤S34,将虚拟坐标层的元素按照中心坐标x与y相加得到坐标之和,坐标之和从小到大的顺序排列;
步骤S35,遍历虚拟元器件的元素,将虚拟元器件的当前元素与当前后的所有元素的中心坐标组成向量,将这些向量放到veclist数组里;
步骤S36,遍历坐标文件,样本找的次数超过了总数的20%就跳过;
步骤S37,遍历veclist数组,将当前的坐标与veclist数组的每一个向量相加,得到新的坐标点,在坐标层搜索到器件,记录搜索到和没搜索到的数量,如果搜索到的数量在90%以上,或者5个以上至少搜索到80%,则找到坐标偏移值;
步骤S38,对虚拟坐标层的每个元素按坐标偏移值偏移,对位成功;
步骤S39,如果对位不成功,虚拟坐标层分别旋转90度、180度、270度、X轴镜像、Y轴镜像,重复步骤S34到步骤S38进行对位,直到对位成功。
步骤S4,坐标文件与虚拟元器件对位校验。
所述步骤S4中,坐标位置对准后,进行焊盘核对,校验对位正确性。针对每个物料建立元件库的2D实物模型,包括本体和引脚的几何信息,通过Bom中的型号、制造商、参数等信息,匹配到元器件,获取元器件所关联的元件库模型。通过元件库引脚的几何数据去搜索该元件的焊盘进行校验。如果整体对齐校验不成功,重复步骤S3中的步骤S39。
坐标文件与虚拟元器件对位校验包括如下步骤:
步骤S41,遍历坐标层下所有器件,通过器件的位号与bom信息(包括型号、制造商、参数等),在元件库中获取元件库模型信息;
步骤S42,在坐标点上将获取到的元件库以坐标位置为中心放置,以元件库的每个引脚为搜索区域,在焊盘层搜索焊盘;
步骤S43,如果搜索到焊盘,当引脚与焊盘接触的面积超过元件引脚面积的70%,视为引脚与焊盘匹配;当所有引脚都匹配到焊盘,即为元件库匹配到焊盘;
步骤S44,如果未匹配到,元件库分别按照90°、180°、270°进行旋转,重复步骤S42,直到匹配为止;
步骤S45,步骤S44中匹配成功,记为true,匹配不成功,记为false,当成功数量超过总数量80%以上,认为虚拟元器件校验成功,否则校验失败,重复步骤S3;
步骤S46,将步骤S44中搜索到并匹配成功的焊盘关联坐标元素,后续验证坐标时使用。
步骤S5,坐标核对与调整。
所述步骤S5包括如下步骤:
步骤S51,遍历坐标层中的坐标元素,获取关联的焊盘,获取所有关联的焊盘极限矩形,计算极限矩形的中心点和坐标值的距离;
步骤S51,如果上述步骤S51中距离偏差在0.2mm以内,记录该坐标核对正确,并将坐标值调整至焊盘极限矩形的中心;否则记录坐标核对可能有问题,需要人工核对。
与现有技术相比,本发明的坐标文件和Gerber文件中焊盘的自动对位方法解决了目前在PCB生成坐标文件,存在位置偏差时,导致效率和质量低,以及处理耗费人力过多的问题,取得了通用性强、能够快速的自动对位,提高设计效率及加工效率,确保生产质量,降低生产品质风险。
以上所述仅为本发明的较佳实施例,并非因此限制本发明的专利范围,凡是在本发明的构思之内所作的任何修改,等同替换和改进等均应包含在本发明的专利保护范围内。
Claims (10)
1.坐标文件和Gerber文件中焊盘的自动对位方法,其特征在于,包括如下步骤:
步骤S1,对Gerber文件进行预处理;
步骤S2,创建虚拟元器件;
步骤S3,虚拟元器件与坐标文件进行对位;
步骤S4,坐标文件与虚拟元器件对位校验;
步骤S5,坐标核对与调整。
2.如权利要求1所述的坐标文件和Gerber文件中焊盘的自动对位方法,其特征在于,所述步骤S2中,参照Gerber文件中的字符层和焊盘层的位置关系,创建虚拟元器件,当字符层和焊盘层符合预设情况,认为当前搜索到的焊盘组成一个元器件,利用这些焊盘创建虚拟元器件对象,将虚拟元器件添加到虚拟元器件数组中。
3.如权利要求2所述的坐标文件和Gerber文件中焊盘的自动对位方法,其特征在于,所述步骤S2包括如下步骤:
步骤SA1,将字符层元素抽网络分析;
步骤SA2,遍历字符层中每个网络,在当前网络极限矩形范围内,搜索与字符接触的焊盘,如果搜索到的焊盘数低于2个,则不符合当前预设;
步骤SA3,将步骤SA2中的焊盘组极限矩形与字符层当前网络的极限矩形对比,当两者的中心距离不超过焊盘组的长或宽的75%,则判断为有效焊盘组,利用该焊盘组创建虚拟元器件,并添加到虚拟元器件数组。
4.如权利要求2所述的坐标文件和Gerber文件中焊盘的自动对位方法,其特征在于,所述步骤S2包括如下步骤:
步骤SB1,确定搜索矩形;
步骤SB2,在搜索矩形范围内,搜索焊盘层与搜索矩形接触的焊盘;
步骤SB3,当搜索到的焊盘数量为2,且两焊盘为水平或垂直关系时,筛选出满足贴片焊盘特征的焊盘创建虚拟元器件,并添加到虚拟元器件数组。
5.如权利要求2所述的坐标文件和Gerber文件中焊盘的自动对位方法,其特征在于,所述步骤S2包括如下步骤:
步骤SC1,遍历未组成有效焊盘组的方形焊盘,将该焊盘加入队列并标记未搜索状态,以第一矩形为搜索范围,搜索周围焊盘;
步骤SC2,如果步骤SC1中搜索到的焊盘没有搜索标记,则将所有搜索到的焊盘添加到待搜索队列;
步骤SC3,将待搜索队列中的种子焊盘删除,以下一个待搜索焊盘为种子焊盘,重复步骤SC1,直到待搜索队列中焊盘数量为零;
步骤SC4,当前搜索到两个焊盘,且焊盘大小误差小于0.1,呈水平或垂直分布,两焊盘距离在0.2到1.0之间,判断搜索到。
6.如权利要求2所述的坐标文件和Gerber文件中焊盘的自动对位方法,其特征在于,所述步骤S3包括如下步骤:
步骤S31,创建虚拟元器件的器件数组zrComp数组,将pin角数量为2的虚拟元器件放到zrComp数组里面;
步骤S32,对zrComp数组的虚拟元器件进行排序,将每个虚拟元器件的中心坐标x与y相加得到坐标之和,按坐标之和从小到大的顺序排列虚拟元器件;
步骤S33,创建一个虚拟坐标层,将坐标文件的对象复制到虚拟坐标层;
步骤S34,将虚拟坐标层的元素按照中心坐标x与y相加得到坐标之和,坐标之和从小到大的顺序排列;
步骤S35,遍历虚拟元器件的元素,将虚拟元器件的当前元素与当前后的所有元素的中心坐标组成向量,将这些向量放到veclist数组里;
步骤S36,遍历坐标文件,样本找的次数超过了总数的20%就跳过;
步骤S37,遍历veclist数组,将当前的坐标与veclist数组的每一个向量相加,得到新的坐标点,在坐标层搜索到器件,记录搜索到和没搜索到的数量,如果搜索到的数量在90%以上,或者5个以上至少搜索到80%,则找到坐标偏移值;
步骤S38,对虚拟坐标层的每个元素按坐标偏移值偏移,对位成功;
步骤S39,如果对位不成功,虚拟坐标层分别旋转90度、180度、270度、X轴镜像、Y轴镜像,重复步骤S34到步骤S38进行对位,直到对位成功。
7.如权利要求6所述的坐标文件和Gerber文件中焊盘的自动对位方法,其特征在于,所述步骤S4包括如下步骤:
步骤S41,遍历坐标层下所有器件,通过器件的位号与bom信息,在元件库中获取元件库模型信息;
步骤S42,在坐标点上将获取到的元件库以坐标位置为中心放置,以元件库的每个引脚为搜索区域,在焊盘层搜索焊盘;
步骤S43,如果搜索到焊盘,当引脚与焊盘接触的面积超过元件引脚面积的70%,视为引脚与焊盘匹配;当所有引脚都匹配到焊盘,即为元件库匹配到焊盘;
步骤S44,如果未匹配到,元件库分别按照90°、180°、270°进行旋转,重复步骤S42,直到匹配为止;
步骤S45,步骤S44中匹配成功,记为true,匹配不成功,记为false,当成功数量超过总数量80%以上,认为虚拟元器件校验成功,否则校验失败,重复步骤S3。
8.如权利要求7所述的坐标文件和Gerber文件中焊盘的自动对位方法,其特征在于,所述步骤S5包括如下步骤:
步骤S51,遍历坐标层中的坐标元素,获取关联的焊盘,获取所有关联的焊盘极限矩形,计算极限矩形的中心点和坐标值的距离;
步骤S51,如果上述步骤S51中距离偏差在0.2mm以内,记录该坐标核对正确,并将坐标值调整至焊盘极限矩形的中心。
9.如权利要求1所述的坐标文件和Gerber文件中焊盘的自动对位方法,其特征在于,所述步骤S1中,对Gerber文件的预处理包括如下两种情形:
情形a,Gerber文件焊盘层存在线弧元素填充的焊盘,将这些线弧元素做铜皮化处理,转成surface;
情形b,Gerber文件是拼版文件,将Gerber文件中字符层和焊盘层处理成单pcs。
10.如权利要求2所述的坐标文件和Gerber文件中焊盘的自动对位方法,其特征在于,所述步骤S2中,包括如下三种情形;
情形A,焊盘与字符元素接触;情形B,成对焊盘与字符存在特定位置关系;情形C,根据焊盘层找成对的双焊盘器件。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111273882.5A CN113966084B (zh) | 2021-10-29 | 2021-10-29 | 坐标文件和Gerber文件中焊盘的自动对位方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111273882.5A CN113966084B (zh) | 2021-10-29 | 2021-10-29 | 坐标文件和Gerber文件中焊盘的自动对位方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN113966084A true CN113966084A (zh) | 2022-01-21 |
CN113966084B CN113966084B (zh) | 2024-06-11 |
Family
ID=79468415
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202111273882.5A Active CN113966084B (zh) | 2021-10-29 | 2021-10-29 | 坐标文件和Gerber文件中焊盘的自动对位方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113966084B (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115758793A (zh) * | 2022-12-06 | 2023-03-07 | 惠州市乐亿通科技有限公司 | 基于gerber文件评估PCB焊盘可制造性的方法 |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS62135966A (ja) * | 1985-06-07 | 1987-06-18 | スクリプテル・コ−ポレ−シヨン | 電子図形システム及び図形作成方法 |
CN101730461A (zh) * | 2008-10-17 | 2010-06-09 | 华南师范大学 | 一种用于bga芯片焊接的对位方法 |
CN102521437A (zh) * | 2011-11-30 | 2012-06-27 | 中国航空工业集团公司第六三一研究所 | 一种采用自动排版生产印制板的方法 |
CN102990179A (zh) * | 2012-10-19 | 2013-03-27 | 廖怀宝 | 一种使用cad文件提高焊锡机器人编程速度和精度的方法 |
CN107844630A (zh) * | 2017-09-28 | 2018-03-27 | 柯马(上海)工程有限公司 | 一种白车身焊接虚拟仿真系统的建立方法 |
CN112916978A (zh) * | 2021-01-22 | 2021-06-08 | 苏州浪潮智能科技有限公司 | 一种波峰焊焊接不良的自动修复方法及dip制程 |
CN113128168A (zh) * | 2019-12-30 | 2021-07-16 | 深圳市三诺数字科技有限公司 | 一种焊盘参数校验校正方法、装置、计算机设备及存储介质 |
-
2021
- 2021-10-29 CN CN202111273882.5A patent/CN113966084B/zh active Active
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS62135966A (ja) * | 1985-06-07 | 1987-06-18 | スクリプテル・コ−ポレ−シヨン | 電子図形システム及び図形作成方法 |
CN101730461A (zh) * | 2008-10-17 | 2010-06-09 | 华南师范大学 | 一种用于bga芯片焊接的对位方法 |
CN102521437A (zh) * | 2011-11-30 | 2012-06-27 | 中国航空工业集团公司第六三一研究所 | 一种采用自动排版生产印制板的方法 |
CN102990179A (zh) * | 2012-10-19 | 2013-03-27 | 廖怀宝 | 一种使用cad文件提高焊锡机器人编程速度和精度的方法 |
CN107844630A (zh) * | 2017-09-28 | 2018-03-27 | 柯马(上海)工程有限公司 | 一种白车身焊接虚拟仿真系统的建立方法 |
CN113128168A (zh) * | 2019-12-30 | 2021-07-16 | 深圳市三诺数字科技有限公司 | 一种焊盘参数校验校正方法、装置、计算机设备及存储介质 |
CN112916978A (zh) * | 2021-01-22 | 2021-06-08 | 苏州浪潮智能科技有限公司 | 一种波峰焊焊接不良的自动修复方法及dip制程 |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115758793A (zh) * | 2022-12-06 | 2023-03-07 | 惠州市乐亿通科技有限公司 | 基于gerber文件评估PCB焊盘可制造性的方法 |
CN115758793B (zh) * | 2022-12-06 | 2023-10-27 | 惠州市乐亿通科技有限公司 | 基于gerber文件评估PCB焊盘可制造性的方法 |
Also Published As
Publication number | Publication date |
---|---|
CN113966084B (zh) | 2024-06-11 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP0577080B1 (en) | Inspection method of inclination of an IC-package | |
US6275971B1 (en) | Methods and apparatus for design rule checking | |
CN107845113B (zh) | 目标元素定位方法、装置以及用户界面测试方法、装置 | |
US7324684B2 (en) | Bonding apparatus | |
CN105510348A (zh) | 一种印制电路板的缺陷检测方法、装置及检测设备 | |
JP3870872B2 (ja) | 検査データ作成方法およびこの方法を用いた基板検査装置 | |
US7496878B2 (en) | Automatic wiring method and apparatus for semiconductor package and automatic identifying method and apparatus for semiconductor package | |
WO2016006076A1 (ja) | 部品装着座標の作成方法および部品装着座標の作成装置 | |
US5801966A (en) | Machine vision methods and articles of manufacture for determination of convex hull and convex hull angle | |
CN113966084B (zh) | 坐标文件和Gerber文件中焊盘的自动对位方法 | |
CN113514475A (zh) | 用于芯片检测的参考模板的生成方法及相关设备 | |
CN117274246A (zh) | 一种焊盘识别方法、计算机设备以及存储介质 | |
KR101441326B1 (ko) | 자동광학검사기의 티칭데이터 자동 생성 장치 및 그 방법 | |
JP3191467B2 (ja) | プリント基板検査データ作成方法 | |
EP0573968A1 (en) | Inspection method of inclination of an IC | |
CN109509165B (zh) | 图像定位区域选取方法及装置 | |
CN116912230A (zh) | 贴片焊接质量检测方法、装置、电子设备和存储介质 | |
WO2001020310A1 (en) | Inspecting component placement relative to component pads | |
JP4160656B2 (ja) | プリント回路基板のテスト方法 | |
CN116128823A (zh) | Ic载板的金点检测方法、装置和电子设备 | |
Nevliudov et al. | Automated System Development for the Printed Circuit Boards Optical Inspection Using Machine Learning Methods | |
US7370303B2 (en) | Method for determining the arrangement of contact areas on the active top side of a semiconductor chip | |
US7191415B2 (en) | Clearance inspection apparatus and clearance inspection method | |
CN113611348B (zh) | 打点方法、装置、电子设备及存储介质 | |
JPH10288505A (ja) | ワークの位置検出方法およびワークの外観検査方法およびこれらの装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |