本文主要是介绍通过修改SPECTRE网表进行后仿,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
参考:关于修改网表进行Spectre的后仿教程与注意事项
寄生参数提取
首先确保layout能够通过DRC和LVS。
PEX-Outputs-Netlist中,Format选择SPECTRE格式,Use Names From选择SCHEMATIC。SPECTRE格式的NETLIST对大小写不敏感,因此这种方式适合原理图中terminal和pin使用不完全使用大写命名的情况。
PEX-Inputs-H-cells选择x-Cell文件,该文件描述的是采用寄生作为设计参数的器件(如mom电容),如果不添加该文件,会出现重复提取的错误。
PEX-PEX Options-Netlist和LVS Options中设置你电路中的电源和地的名称。
然后Run PEX就就可以进行抽取。
抽取完成后,在之前指定的抽取路径中找到pex.netlist文件与pxi文件:
pex.netlist是后抽的网表,里面是最顶层的器件和连接关系,pxi文件为寄生参数文件。另外,pex.netlist中include了pxi文件,因此需要注意不要改名,且这两个文件应在同一路径下。(如果要修改的话,应修改对应路径)
修改SPECTRE网表
找到前仿产生的网表(Simulation文件夹中的input.scs),在pex.netlist中修改两个内容:
1.顶层电路的名字,改为和input.scs一致
2.顶层电路的端口顺序,改为和inpus.scs一致
例如,在input.scs中的顶层电路名为your_circuit
, 端口顺序为PORT0 PORT1 PORT2 PORT3
,则pex.netlist中改为:
// ...pex.netlist
// Created: Tue Dec 12:00:00 2023
// Program "Calibre xRC"
// Version "v2019.3_15.11"
//
simulator lang=spectre
include "your_circuit.pex.netlist.pex"
subckt your_circuit ( PORT0 PORT1 PORT2 PORT4 )
修改完毕之后,在ADE中把pex.netlist添加到Model Library并勾选:
然后再重新生成网表input.scs,新的input.scs中会include这个pex.netlist:
pex.netlist已经对各个子电路模块定义过了,input.scs中原来定义的subckt就不需要了,需要把所有的子电路定义部分全部删除,只保留顶层的测试电路(testbench)部分。如果不删干净,在仿真时则会出现重复定义(redefine)的错误。
简单来说,pex.netlist是一个包含了提取出来的寄生参数信息的网表,我们要使用它进行仿真。具体做法就是通过原来前仿的网表input.scs去调用它,同时把Input.scs中用不到的原来的子电路全部删除,防止定义冲突。
仿真
以上所有修改都完成后,使用Simulation-Run仿真,不要使用Netlist and Run,否则会新生成一个input.scs把修改好的覆盖掉。
这篇关于通过修改SPECTRE网表进行后仿的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!