CN113255268A - 一种电路仿真中瞬态分析不收敛的检测及修复方法 - Google Patents
一种电路仿真中瞬态分析不收敛的检测及修复方法 Download PDFInfo
- Publication number
- CN113255268A CN113255268A CN202110558250.7A CN202110558250A CN113255268A CN 113255268 A CN113255268 A CN 113255268A CN 202110558250 A CN202110558250 A CN 202110558250A CN 113255268 A CN113255268 A CN 113255268A
- Authority
- CN
- China
- Prior art keywords
- convergence
- step size
- repairing
- detecting
- transient analysis
- 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
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F30/00—Computer-aided design [CAD]
- G06F30/30—Circuit design
- G06F30/32—Circuit design at the digital level
- G06F30/337—Design optimisation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F17/00—Digital computing or data processing equipment or methods, specially adapted for specific functions
- G06F17/10—Complex mathematical operations
- G06F17/11—Complex mathematical operations for solving equations, e.g. nonlinear equations, general mathematical optimization problems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F30/00—Computer-aided design [CAD]
- G06F30/30—Circuit design
- G06F30/32—Circuit design at the digital level
- G06F30/33—Design verification, e.g. functional simulation or model checking
- G06F30/3308—Design verification, e.g. functional simulation or model checking using simulation
Landscapes
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Computer Hardware Design (AREA)
- General Physics & Mathematics (AREA)
- Mathematical Physics (AREA)
- General Engineering & Computer Science (AREA)
- Mathematical Optimization (AREA)
- Computational Mathematics (AREA)
- Mathematical Analysis (AREA)
- Geometry (AREA)
- Evolutionary Computation (AREA)
- Pure & Applied Mathematics (AREA)
- Data Mining & Analysis (AREA)
- Operations Research (AREA)
- Algebra (AREA)
- Databases & Information Systems (AREA)
- Software Systems (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
- Design And Manufacture Of Integrated Circuits (AREA)
Abstract
一种电路仿真中瞬态分析不收敛的检测及修复方法,包括以下步骤:1)设置仿真时间步长并确定时间点;2)牛顿迭代解差分方程;3)确认迭代不收敛且截断误差不符合条件;4)确认符合调整步长条件;5)调整步长进行下一步仿真。本发明的电路仿真中瞬态分析不收敛的检测及修复方法,可以自动解决收敛问题,大大节约了电路设计者的时间。
Description
技术领域
本发明涉及EDA电路仿真技术领域,尤其涉及电路仿真中电路的瞬态分析方法。
背景技术
电路仿真中的瞬态分析,是求解电路的时域响应。进行瞬态分析时,电路由一组常微分方程来描述,因此电路瞬态分析的实质就是如何求解常微分方程。
目前求解常微分方程的方法均采用数值积分方法,用数值积分法求解瞬态分析的过程主要分四步:对电路网络建模得到代数微分方程;将时间离散化;在各个时间点上将微分方程化为差分方程;求解差分(非线性)方程。在求解非线性方程时通常采用牛顿-拉夫森方法,每一次迭代需要求解以下公式:
J(Xk)*ΔX=-F(Xk) (1)
ΔX=Xk+1-Xk (2)
其中,J(Xk)代表系数矩阵;ΔX表示未知数向量,即相邻两次迭代节点电压的差值;-F(Xk)表示右端项,是由model方程计算得出的。
发明内容
为了解决现有技术存在的不足,本发明的目的在于提供一种电路仿真中瞬态分析不收敛的检测及修复方法,可以自动检查瞬态分析不收敛情况并进行修复,从而加快方程迭代的收敛速度。
为实现上述目的,本发明提供的一种电路仿真中解决瞬态分析不收敛的方法,包括以下步骤:
1)设置仿真时间步长并确定时间点;
2)牛顿迭代解差分方程;
3)确认迭代不收敛且截断误差不符合条件;
4)确认符合调整步长条件;
5)调整步长进行下一步仿真。
进一步的,所述步骤4)还包括,
确认牛顿迭代不收敛且步长小于最小步长和/或牛顿迭代不收敛且步长放大次数小于阈值。
进一步的,所述最小步长根据电路属性确定。
进一步的,所述阈值,为2到10之间的整数。
进一步的,所述步骤5)还包括,
如果牛顿迭代不收敛、步长小于最小步长且步长放大次数小于阈值,则放大步长;
进一步的,所述放大步长的方法采用指数法,步长h=h*an,其中,n代表步长放大的次数,a为2≤a≤10的整数。
进一步的,如果牛顿迭代不满足不收敛且步长小于最小步长的条件,则缩小步长。
更进一步的,还包括,调整收敛条件以保证收敛。
为实现上述目的,本发明还提供一种电子设备,包括存储器和处理器,所述存储器上储存有在所述处理器上运行的程序,所述处理器运行所述程序时执行上述电路仿真中瞬态分析不收敛的检测及修复方法的步骤。
为实现上述目的,本发明还提供一种计算机可读存储介质,其上存储有计算机指令,所述计算机指令运行时执行上述电路仿真中瞬态分析不收敛的检测及修复方法的步骤。
本发明的电路仿真中瞬态分析不收敛的检测及修复方法,相对于现有技术,具有如下的有益效果:在以往电路仿真中,瞬态分析某个时间点不收敛时,通常会缩小步长,以增加差分方程的精度。但如果电路中有比较大的电容,步长越小,动态电流越大,右端项更难收敛。当步长小于阈值时,则认为该瞬态分析不能收敛,仿真失败。目前遇到不收敛时,只能停止,让仿真产品工程师去解决问题,重启仿真。本发明提供的一种电路仿真中解决瞬态分析不收敛的方法,可以自动解决部分收敛问题,大大节约了电路设计者的时间。
本发明的其它特征和优点将在随后的说明书中阐述,并且,部分地从说明书中变得显而易见,或者通过实施本发明而了解。
附图说明
附图用来提供对本发明的进一步理解,并且构成说明书的一部分,并与本发明的实施例一起,用于解释本发明,并不构成对本发明的限制。在附图中:
图1为根据本发明的电路仿真中瞬态分析不收敛的检测及修复方法流程图。
具体实施方式
以下结合附图对本发明的优选实施例进行说明,应当理解,此处所描述的优选实施例仅用于说明和解释本发明,并不用于限定本发明。
本发明实施例中,将时间点离散化,每个时间点由微分方程变为差分方程,也就是非线性代数方程。非线性代数方程通常用牛顿-拉夫森迭代法求解,每一次迭代都求解线性方程组;求解之后,是否满足收敛条件,如果不收敛则进入步长调整流程。如果符合放大步长的条件,则将步长放大,进入下一个步骤,同时放松收敛条件,保证收敛。
实施例1
图1为根据本发明的电路仿真中瞬态分析不收敛的检测及修复方法流程图,下面将参考图1,对本发明的电路仿真中瞬态分析不收敛的检测及修复方法进行详细描述。
在步骤101,设置仿真时间步长。
本发明实施例中,在仿真过程中,将时间点离散化,将每个时间点由微分方程变为差分方程,也就是非线性代数方程。非线性代数方程通常用牛顿-拉夫森迭代法求解,每一次迭代都求解线性方程组(1)。在求解过程中,需要设置时间步长,在该步骤中,设置时间步长为h,时间tn=tn-1+h。
在步骤102,牛顿迭代解差分方程。
本发明实施例中,将步骤101中计算得到的tn带入牛顿迭代方程,求解差分方程。
在步骤103,判断收敛和截断误差是否符合条件。
本发明实施例中,在瞬态分析的一个时间点中,当牛顿迭代结束时,需判断牛顿迭代方程所求的解是否满足收敛条件,且截断误差是否符合条件。
如果满足收敛条件且截断误差符合条件,则维持现有步长,进行下一步仿真,继续进行步骤101-103。如果不收敛或截断误差不符合条件,则进行步骤104。
在步骤104中,判断是否符合放大步长条件。
在该步骤中所指的放大步长的条件包括以下两个条件:
a)牛顿迭代不收敛且步长小于最小步长;
其中,关于最小步长,可以根据电路的属性确定,例如可以是1e-15到1e-17。
b)牛顿迭代不收敛且步长放大次数小于阈值。
其中,判断放大次数是否超过阈值中的阈值可根据电路类型和最小步长,取大于等于2且小于等于10的整数。
具体地,如果牛顿迭代满足条件a)和条件b),则放大步长,返回步骤101并进行后续步骤。其中放大步长的方法,一般采用指数法,步长h=h*an,n代表步长放大的次数,a代表每次放大的倍数,是经验值,也就是根据遇到的不收敛情况试出来比较有效的值,其取值为2≤a≤10的整数。
在将步长放大的同时,应放松收敛条件,保证收敛,即,在进入步长放大的流程后,牛顿迭代收敛条件的判定要适当放松,通常ΔX的tolerence放大2到4倍,右端项的tolerence放大4到16倍;或者只判断右端项收敛。
本发明实施例中,ΔX表示未知数向量,即相邻两次迭代节点电压的差值。NR迭代的收敛条件就是相邻两次解的差值足够小。
如果牛顿迭代不满足条件a),则缩小步长,返回步骤101并进行后续步骤。
如果牛顿迭代满足条件a)但不满足条件b),则终止瞬态分析,报不收敛。
实施例2
本发明还提供一种电子设备,包括存储器和处理器,存储器上储存有在处理器上运行的程序,处理器运行所述程序时执行上述电路仿真中瞬态分析不收敛的检测及修复方法的步骤。
实施例3
本发明还提供了一种计算机可读存储介质,其上存储有计算机指令,所述计算机指令运行时执行上述电路仿真中瞬态分析不收敛的检测及修复方法的步骤,所述电路仿真中瞬态分析不收敛的检测及修复方法参见前述部分的介绍,不再赘述。
本领域普通技术人员可以理解:以上所述仅为本发明的优选实施例而已,并不用于限制本发明,尽管参照前述实施例对本发明进行了详细的说明,对于本领域的技术人员来说,其依然可以对前述各实施例记载的技术方案进行修改,或者对其中部分技术特征进行等同替换。凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。
Claims (10)
1.一种电路仿真中瞬态分析不收敛的检测及修复方法,包括以下步骤:
1)设置仿真时间步长并确定时间点;
2)牛顿迭代解差分方程;
3)确认迭代不收敛且截断误差不符合条件;
4)确认符合调整步长条件;
5)调整步长进行下一步仿真。
2.根据权利要求1所述的电路仿真中瞬态分析不收敛的检测及修复方法,其特征在于,所述步骤4)还包括,
确认牛顿迭代不收敛且步长小于最小步长和/或牛顿迭代不收敛且步长放大次数小于阈值。
3.根据权利要求2所述的电路仿真中瞬态分析不收敛的检测及修复方法,其特征在于,所述最小步长根据电路属性确定。
4.根据权利要求2所述的电路仿真中瞬态分析不收敛的检测及修复方法,其特征在于,所述阈值,为2到10之间的整数。
5.根据权利要求1所述的电路仿真中瞬态分析不收敛的检测及修复方法,其特征在于,所述步骤5)还包括,
如果牛顿迭代不收敛、步长小于最小步长且步长放大次数小于阈值,则放大步长。
6.根据权利要求5所述的电路仿真中瞬态分析不收敛的检测及修复方法,其特征在于,所述放大步长的方法采用指数法,步长h=h*an,其中,n代表步长放大的次数,a为2≤a≤10的整数。
7.根据权利要求2所述的电路仿真中瞬态分析不收敛的检测及修复方法,其特征在于,如果牛顿迭代不满足不收敛且步长小于最小步长的条件,则缩小步长。
8.根据权利要求6或7所述的电路仿真中瞬态分析不收敛的检测及修复方法,其特征在于,还包括,调整收敛条件以保证收敛。
9.一种电子设备,其特征在于,包括存储器和处理器,所述存储器上储存有在所述处理器上运行的程序,所述处理器运行所述程序时执行权利要求1-8任一项所述的电路仿真中瞬态分析不收敛的检测及修复方法的步骤。
10.一种计算机可读存储介质,其上存储有计算机指令,其特征在于,所述计算机指令运行时执行权利要求1-8任一项所述的电路仿真中瞬态分析不收敛的检测及修复方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110558250.7A CN113255268B (zh) | 2021-05-21 | 2021-05-21 | 一种电路仿真中瞬态分析不收敛的检测及修复方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110558250.7A CN113255268B (zh) | 2021-05-21 | 2021-05-21 | 一种电路仿真中瞬态分析不收敛的检测及修复方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN113255268A true CN113255268A (zh) | 2021-08-13 |
CN113255268B CN113255268B (zh) | 2022-05-24 |
Family
ID=77183632
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110558250.7A Active CN113255268B (zh) | 2021-05-21 | 2021-05-21 | 一种电路仿真中瞬态分析不收敛的检测及修复方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113255268B (zh) |
Citations (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101770532A (zh) * | 2008-12-30 | 2010-07-07 | 北京华大九天软件有限公司 | 一种提高电路仿真器收敛性的方法 |
CN101770531A (zh) * | 2008-12-30 | 2010-07-07 | 北京华大九天软件有限公司 | 一种提高电路仿真运行速度的方法 |
CN102054069A (zh) * | 2009-10-30 | 2011-05-11 | 新思科技(上海)有限公司 | 非线性电路直流工作点的伪瞬态分析方法与装置 |
CN102142052A (zh) * | 2011-03-28 | 2011-08-03 | 清华大学 | 一种针对电路仿真中电路稀疏矩阵的快速lu分解方法 |
TW201128427A (en) * | 2010-02-12 | 2011-08-16 | Synopsys Shanghai Co Ltd | Method of false transient analysis for the DC operating point of a nonlinear circuit and the apparatus thereof |
CN102682195A (zh) * | 2012-03-09 | 2012-09-19 | 中国石油大学(华东) | 半潜式平台瞬态钻井井筒温度计算方法 |
CN103198198A (zh) * | 2013-04-18 | 2013-07-10 | 西北核技术研究所 | 一种针对高频电路的单粒子瞬态效应注入仿真方法 |
US20130246015A1 (en) * | 2012-03-13 | 2013-09-19 | Synopsys, Inc. | Electronic Circuit Simulation Method With Adaptive Iteration |
CN108763670A (zh) * | 2018-05-15 | 2018-11-06 | 西安交通大学 | 一种求解超临界二氧化碳反应堆布雷顿循环瞬态过程方法 |
CN109543264A (zh) * | 2018-11-12 | 2019-03-29 | 天津理工大学 | 一种基于多维度重构校正的柔性多体机器人建模与求解方法 |
CN109684734A (zh) * | 2018-12-26 | 2019-04-26 | 北京华大九天软件有限公司 | 一种检查模型矩阵的方法 |
CN111523282A (zh) * | 2020-05-07 | 2020-08-11 | 深圳探科技术有限公司 | 集成电路仿真中数据处理的方法、模块、存储介质及系统 |
CN112464436A (zh) * | 2020-10-30 | 2021-03-09 | 海南电网有限责任公司电力科学研究院 | 一种用于电力仿真模型参数辨识的步长调节方法 |
-
2021
- 2021-05-21 CN CN202110558250.7A patent/CN113255268B/zh active Active
Patent Citations (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101770531A (zh) * | 2008-12-30 | 2010-07-07 | 北京华大九天软件有限公司 | 一种提高电路仿真运行速度的方法 |
CN101770532A (zh) * | 2008-12-30 | 2010-07-07 | 北京华大九天软件有限公司 | 一种提高电路仿真器收敛性的方法 |
CN102054069A (zh) * | 2009-10-30 | 2011-05-11 | 新思科技(上海)有限公司 | 非线性电路直流工作点的伪瞬态分析方法与装置 |
TW201128427A (en) * | 2010-02-12 | 2011-08-16 | Synopsys Shanghai Co Ltd | Method of false transient analysis for the DC operating point of a nonlinear circuit and the apparatus thereof |
CN102142052A (zh) * | 2011-03-28 | 2011-08-03 | 清华大学 | 一种针对电路仿真中电路稀疏矩阵的快速lu分解方法 |
CN102682195A (zh) * | 2012-03-09 | 2012-09-19 | 中国石油大学(华东) | 半潜式平台瞬态钻井井筒温度计算方法 |
US20130246015A1 (en) * | 2012-03-13 | 2013-09-19 | Synopsys, Inc. | Electronic Circuit Simulation Method With Adaptive Iteration |
CN103198198A (zh) * | 2013-04-18 | 2013-07-10 | 西北核技术研究所 | 一种针对高频电路的单粒子瞬态效应注入仿真方法 |
CN108763670A (zh) * | 2018-05-15 | 2018-11-06 | 西安交通大学 | 一种求解超临界二氧化碳反应堆布雷顿循环瞬态过程方法 |
CN109543264A (zh) * | 2018-11-12 | 2019-03-29 | 天津理工大学 | 一种基于多维度重构校正的柔性多体机器人建模与求解方法 |
CN109684734A (zh) * | 2018-12-26 | 2019-04-26 | 北京华大九天软件有限公司 | 一种检查模型矩阵的方法 |
CN111523282A (zh) * | 2020-05-07 | 2020-08-11 | 深圳探科技术有限公司 | 集成电路仿真中数据处理的方法、模块、存储介质及系统 |
CN112464436A (zh) * | 2020-10-30 | 2021-03-09 | 海南电网有限责任公司电力科学研究院 | 一种用于电力仿真模型参数辨识的步长调节方法 |
Non-Patent Citations (2)
Title |
---|
刘金魁 等: "直流电动机的仿真研究", 《漯河职业技术学院学报》 * |
尹有为等: "基于非线性迭代的开关功率变换器仿真", 《空军工程大学学报(自然科学版)》 * |
Also Published As
Publication number | Publication date |
---|---|
CN113255268B (zh) | 2022-05-24 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
Rewieński et al. | Model order reduction for nonlinear dynamical systems based on trajectory piecewise-linear approximations | |
CN109495348B (zh) | 一种具有时延和数据包丢失的网络控制系统h∞故障检测方法 | |
CN107016155B (zh) | 非线性pde和线性求解器的收敛估计 | |
CN108445759B (zh) | 一种传感器饱和约束下网络化系统的随机故障检测方法 | |
Fabozzi et al. | On simplified handling of state events in time-domain simulation | |
KR20100080331A (ko) | 관련된 디바이스들을 위한 일관성 있는 컴팩트 모델 파라미터들 추출 | |
CN109063401B (zh) | 采用等效静态位移实现结构接触力优化的方法 | |
CN113255268B (zh) | 一种电路仿真中瞬态分析不收敛的检测及修复方法 | |
CN110580391B (zh) | 一种柔性结构的基频模态测量方法 | |
US8645883B2 (en) | Integrated circuit simulation using fundamental and derivative circuit runs | |
CN114586036A (zh) | 利用寄存器传输级矢量的毛刺功率分析 | |
CN113033128B (zh) | 一种选取电路仿真中牛顿迭代的初值的方法 | |
CN111414724B (zh) | 电路仿真优化的方法 | |
KR20000023565A (ko) | 컴퓨터를 사용한 시스템 관계 함수 결정 방법 및 장치 | |
US8185369B2 (en) | Method and apparatus for characterizing properties of electronic devices depending on device parameters | |
CN112989738B (zh) | 一种电路仿真中牛顿迭代的收敛判定的改进方法 | |
Yazdi et al. | A proposed damping coefficient of quick adaptive Galerkin finite volume solver for elasticity problems | |
CN113032718B (zh) | 解决电路仿真中牛顿迭代算法死循环的方法及装置 | |
Nishikawa | On Estimating Machine-Zero Residual | |
CN113128157B (zh) | 一种模拟电路仿真中解决高阻态节点不收敛的方法及装置 | |
CN112949240B (zh) | 一种集中参数模型多物理场耦合仿真方法 | |
TWI476616B (zh) | Estimation Method and Device of Initial Value for Simulation of DC Working Point | |
CN116244894B (zh) | 一种基于大步长的电力系统暂态仿真方法及系统 | |
CN113255275B (zh) | 一种基于不光滑波形的时间离散格式切换方法 | |
TWI486803B (zh) | Pseudo - transient analysis method and device for DC operating point of nonlinear circuit |
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 |