当前位置:首页 > 厂商动态 > ADI
[导读]本文讨论如何在LTspice®仿真中利用flat()、gauss()和mc()函数来实现伪随机数和真随机数的生成,并介绍如何使用设置面板的Hacks部分中的Use the clock to reseed the MC generator(使用时钟重新设置MC生成器的随机种子)选项。文章探讨了伪随机数和真随机数之间的利弊权衡,同时比较了蒙特卡罗统计仿真与更有针对性的最坏情况仿真之间的差异。

摘要

本文讨论如何在LTspice®仿真中利用flat()、gauss()和mc()函数来实现伪随机数和真随机数的生成,并介绍如何使用设置面板的Hacks部分中的Use the clock to reseed the MC generator(使用时钟重新设置MC生成器的随机种子)选项。文章探讨了伪随机数和真随机数之间的利弊权衡,同时比较了蒙特卡罗统计仿真与更有针对性的最坏情况仿真之间的差异。

引言

在LTspice®原理图中,有多种方法可模拟随机性。LTspice中的flat()、gauss()和mc()函数支持在LTspice仿真中引入随机性。本文以mc()函数为例,说明如何模拟无源元件值的容差。打开LTspice后,选择Help > LTspice Help(“帮助”>“LTspice帮助”,或按F1)可打开《帮助手册》,了解有关flat()和gauss()的更多信息。

图1中的示例使用mc()来设置R1和C1的标称值和容差。例如,R1的标称值为10 kΩ,容差为5%。mc(x,y)函数将生成在x*(1-y)和x*(1+y)之间均匀分布的伪随机数。请继续阅读,深入了解伪随机数和真随机数之间的区别,以及如何强制LTspice生成真随机数。.STEP指令用于指示LTspice运行仿真的迭代次数。在下面的示例中,.STEP指令以1为增量将一个虚拟参数从1逐步增加到100,从而进行100次仿真运行,其中R1和C1的值都是随机生成。

图1.RC电路使用mc()来设置无源元件的值和容差

观察mc()函数在每一步迭代中的行为:图2显示了一个仅使用电压源的简单示例。此示例使用mc()将标称电压设置为10 V,并将容差设置为100%。因此,预计将得到一个在0 V和20 V之间均匀分布的电压。从波形查看器和SPICE输出日志中的结果可以看到,在10次迭代中,电压变化范围是2.7 V至19.92 V,分布并不完全均匀,但更多次迭代将有助于确保结果在统计上更加合理。

我们不妨更仔细地观察,并反复运行这个仿真。在这些仿真过程中,数值是否发生了变化?在我的计算机上,每次运行仿真时,每一步迭代都得到相同的电压值。这称得上“随机”吗?

图2.电压源使用mc()生成随机电压

您所看到的是代码和计算机在生成随机数时的典型表现。编程语言中的随机数生成器有一个与之关联的可选seed()方法。想要获得真随机数(即每次运行程序时得到不同的随机数),需要调用seed()方法,并为其指定动态变化的种子值。通常,程序员会将当前系统时间传递给seed()方法来实现这种随机性。

这与我们的LTspice仿真有何关系?如果希望每次运行仿真时获得不同的随机值,则必须在设置面板的Hacks部分中启用Use the clock to reseed the MC generator选项(参见图3)。

图3.LTspice设置面板的Hacks选项卡,显示了如何实现真随机性

此Use the clock to reseed the MC generator选项也适用于flat()和gauss()函数。这些函数可以用在mc()所使用的地方。

不过,请慎重考虑否是需要刻意实现这种仿真行为。您希望仿真过程是真随机的吗?倘若如此,您的仿真将失去可预测性和可重复性。

为了说明这一点,让我们回顾图2中的示例。如果目标是模拟一个在0 V和20 V之间均匀分布的电压呢?当前的示例不太符合预期。然而,通过将迭代次数从10次增加到100次,我们可以使仿真结果更接近目标(图4)。这种调整使得仿真更接近实现预期的分布范围。

图4.使用mc()且迭代更多次数的电压源

现在有两点已经很明确:(a) mc()迭代运行100次,便能得到一个相当好的数值分布;(b)如果不启用reseed the MC generator(重新设置MC生成器的随机种子)功能,则每次运行仿真将得到可重复的结果。

如果电路中多处使用mc()呢?能否保证通过100次迭代能够覆盖所有容差?图5展现了这一尝试,其中显示了两个使用mc()的电压源。将V(out1)作为y轴、V(out2)作为x轴进行绘图,可以清楚地看到,V1和V2的组合呈现出高度随机的坐标分布(右键单击x轴标题,将x轴从步进虚拟参数更改为V(out2))。但从技术上讲,这些电压的最小值和最大值并非同时达到,导致极端(角落)情况的覆盖有些不足。

图5.绘制一次仿真中两个mc()电压的结果

如果目标是接近完全覆盖,则需要更多次迭代(图6)。

图6.绘制更多次迭代的结果

对于这个简单的例子,仿真运行速度相当快,即便运行1000次也毫无问题。但如果仿真运行时间很长,运行多次迭代需要数小时或数天时间呢?应考虑启用Use the clock to reseed the MC generator选项是否有帮助。如果在一次仿真运行中,mc()生成的值令人满意,那么接下来的目标是让这些结果在每次运行时可重复,还是随机变化呢?启用此项功能之前,这是一个值得考虑的好问题。

为了大幅缩短仿真时间,我们来看一种相对不太随机的方法。

图7所示的例子确保了仿真能够覆盖无源元件容差的所有边缘情况,同时保持总体仿真时间尽可能短。这个例子遍历了R1的三个值和C1的三个值,进行了九次仿真,并覆盖了元件值同时达到最小值(或最大值)的情形。

图7.设置元件的特定值以模拟容差导致的行为

结语

如果目标是探索电路在极端工况下的行为,则相对不太随机的方法可能更为合适。相反,如果目标是对仿真在一系列变化下的行为进行统计分析,则使用大量仿真并通过随机函数引入随机性可能是更好的方法。但无论哪种情况,您现在应该已经对如何在LTspice仿真中引入(或不引入)随机性有了更好的理解。

欲了解更多信息,请阅读文章“如何使用LTspice对复杂电路的统计容差分析进行建模”。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除( 邮箱:macysun@21ic.com )。
换一批
延伸阅读

在下述的内容中,小编将会对断路器的相关消息予以报道,如果断路器是您想要了解的焦点之一,不妨和小编共同阅读这篇文章哦。

关键字: 断路器 电路 智能化

电源作为电子设备的“心脏”,其安全性直接决定设备可靠性、使用寿命乃至人员财产安全。在复杂的用电环境中,电压波动、电流异常、负载故障、环境干扰等因素,都可能导致电源损坏、设备瘫痪,甚至引发火灾、触电等严重安全事故。保护电路...

关键字: 电源 电路 保护

电路稳定性是硬件设计的生命线,它直接决定了产品在不同环境、不同负载条件下的可靠运行能力。然而,很多工程师在设计过程中,由于对电路原理理解不深、经验不足或过度依赖“经验主义”,容易陷入稳定性设计的误区,导致产品在测试或量产...

关键字: 电路 稳定性

在电机控制系统设计中,集成电机驱动芯片的供电方案直接影响系统稳定性、能效与成本。不少工程师在选型与电路设计时都会面临核心疑问:集成电机驱动芯片是否必须额外添加降压供电?答案并非绝对,需结合芯片内置功能、输入电压范围、负载...

关键字: 电机控制 驱动芯片 电路

一直以来,弱电的使用都是大家的关注焦点之一。因此针对大家的兴趣点所在,小编将为大家带来弱电的相关介绍,详细内容请看下文。

关键字: 弱电 弱电系统 电路

本文将逐步介绍如何将第三方SPICE模型导入到LTspice中。文中涵盖了两类不同模型的导入过程:使用.MODEL指令实现的模型,以及用.SUBCKT实现的模型。所提供的步骤旨在确保共享原理图时能够具备可移植性。

关键字: LTspice 电路元件 SPICE模型

ADI Power Studio™是一套面向应用工程师及高级电源设计用户的综合性产品系列,能够有效简化整个电源系统的设计流程,提供从初步概念到测量和评估的全程支持。Power Studio提供统一、直观的工作流程,利用准...

关键字: 电源管理 LTspice 稳压器

本文介绍一款小尺寸、功能强大、低噪声的单芯片同步升压转换器。文章重点介绍了该集成电路的多个特性。这些特性能够增强电路性能,并支持定制,以满足各种应用的要求。

关键字: 升压转换器 集成电路 电路

在电子电路设计领域,放大器是极为关键的元件,用于增强电信号的幅度,以满足各类电子设备的需求。内置增益设置电阻的放大器和分立差动放大器是两种常见类型,它们在电路结构、性能表现、成本以及设计灵活性等方面存在诸多不同。深入了解...

关键字: 放大器 电信号 电路

本文介绍了一种进行控制回路仿真的简便方法,使用LTspice®可以轻松生成波特图。

关键字: LTspice EMC 开关稳压器
关闭