基于FPGA的电力电子系统电磁暂态实时仿真通用解算器

(海军工程大学舰船综合电力技术国防科技重点实验室武汉430033)

摘要电力电子系统较高的开关频率给传统以CPU为计算核心的电磁暂态(EMT)实时仿真带来了挑战。为了实现小步长实时仿真,该文提出并实现一款基于FPGA的EMT实时仿真解算器。该解算器的通用化框架分为离线和在线两部分,离线程序能够自动获取仿真模型的参数并生成计算数据,在线程序能够自动配置计算资源与控制逻辑。为了提高仿真速度,还提出一种低延迟的单周期浮点累加方法,用于构建解算器的基本计算单元。基于XilinxVirtex7xc7vx485t型FPGA芯片的评估与分析结果表明:相比某商业FPGA实时仿真解算器,该文解算器的仿真速度提高了一倍,仿真规模增加了29.69%~79.17%。最后,还通过两种电力电子变换器的实时仿真测试,验证了它的实际性能。所提解算器能够达到400MHz的运行速度、100ns级的仿真步长并保持较高的仿真精度,具有通用性强、自动化程度高、配置灵活等特点。

关键词:电力电子系统FPGA实时仿真通用解算器浮点数乘累加

电磁暂态(Electro-MagneticTransient,EMT)实时仿真在航空航天、轨道交通和电力系统等领域被广泛应用,贯穿于研发设计到验证测试等各个环节[1-3]。为了追求高功率密度、低总体谐波分布,电力电子系统的开关频率趋于高频化[4]。传统以CPU为计算核心的EMT实时仿真,它们以5~10ms的最小仿真步长难以准确刻画开关的高频特性[5]。FPGA强大的并行计算能力、高带宽低延迟的I/O接口能够更准确地描述电力电子拓扑的开关事件[1]。以FPGA为计算核心进行实时仿真已成为一种趋势[6-8]。

FPGA编程门槛高、开发周期长,增加了它用于实时仿真的难度。当前一种比较好的解决思路是基于通用解算器的仿真方法[9-13]。不同电路的数学模型可以统一为代数-微分方程组的形式[2]。如果方程求解程序实现了通用化,仿真时只需将其固化就可以处理不同的仿真对象,无需重复编程。Opal-RT公司在2011年公开了其FPGA实时仿真通用解算器的最早版本[9],并提出新的浮点乘累加(Floating-PointMultiply-Accumulate,FPMAC)实现方法用于解算器的计算引擎[10]。为了提高仿真速度,MAC又被替换为并行度更大的向量点积(DotProduct,DP)[11],但两者都未能很好地处理浮点累加运算,导致仿真速度受限。文献[12-13]提出了基于定点数的FPGA实时仿真解算器,可时钟频率仅有40MHz。文献[14-16]针对有源配电网设计了基于矩阵分解运算的通用解算器,其用于机电暂态的仿真步长不太适合电力电子系统。

FPGA实时仿真的另一大难点是如何在完成高复杂度、大规模迭代计算的同时保证仿真的实时性。这不仅取决于计算核心的硬件能力,还与元器件的建模方法、电路方程的组织形式、解算器的框架以及程序设计等有关,尤其是开关器件模型,它几乎影响所有仿真环节。当前FPGA实时仿真中的开关模型主要有双值电阻模型与LC等效模型两类。双值电阻模型精度更高,但会造成电路方程的导纳矩阵时变。文献[14,17]通过预存所有导纳矩阵逆矩阵的方法简化计算,不过仿真规模有限。LC等效模型具有恒定的开关导纳[18],在当前FPGA实时仿真中广泛应用[19-20]。针对该模型引入人为振荡的问题,文献[21-23]已提出多种解决方案。

本文提出并实现了一款基于FPGA的电力电子系统EMT实时仿真通用解算器。相比文献[9-13]中报道的和现有的商业实时仿真解算器,它的特点在于:①依据仿真模型中状态量与测量量的情况,将基于固定导纳矩阵节点法(FixedAdmittanceMatrixNodalMethod,FAMNM)生成的电路方程重写为状态空间的形式,提高仿真的实时性;②解算器通用框架分为离线与在线两部分,离线程序自动获取仿真模型的参数并生成计算数据,在线程序根据参数自动配置计算资源与控制逻辑,通用框架还可以配置资源的复用程度;③生成计算数据时考虑多个仿真工况的切换,并将多个数据拼接后再写入同一个初始化文件,以提高存储资源的利用率;④提出一种低延迟的单周期浮点累加实现方法,用于构建以FPMAC为基本计算单元的计算引擎,使得解算器最终取得极高的运行速度。

那么开关导纳将不随开关状态变化,节点导纳矩阵也会保持固定不变。因此,FAMNM既保持了预存逆矩阵方法计算简单的优点,又不需要过多的存储资源。

对于一个有Nn个独立节点、Nvs个独立电压源的电路,根据FAMNM得到的节点方程为

式中,Gn为节点导纳矩阵;向量in包含Nn个节点注入电流和Nvs个独立电压源;向量vn为独立节点的电压和独立电压源的支路电流。

电力电子系统的节点方程是基于差分电路得出的,必须确定合适的数值积分方法。EMT仿真最常用的梯形法和后向欧拉法中,梯形法精度高,但用在含开关的电路时会有数值振荡[26]。通常选择后向欧拉法,因为它具有的阻尼作用可以较好地抑制开关动作引起的振荡,并且在实时仿真的步长下能够提供足够的精度和刚性[27]。

假设电路中Nd个独立动态元件和Ns个开关在离散后分别形成了历史电流源向量ih_d、ih_s,它们共同组成状态向量x;Nu个独立输入源组成输入向量u。记

式(2)中的向量in可以重新表示为

(4)

矩阵M的(Nn+Nvs)×(Nd+Ns+Nu)个元素全部由-1,0,1组成。式(2)中的向量vn表示为

相似地,将Nb个支路的支路电流向量ib表示为

(6)

式中,矩阵N的Nb×(Nd+Ns+Nu)个元素全部由-1,0,1组成的。支路导纳矩阵Gb含Nb×(Nn+Nvs)个元素,每行分别为相应支路的导纳。

记A=,B=+N。根据算法1(见附录)的流程组织状态更新矩阵T。由于下一步长的ih_s需要从本步长的开关电压电流中选择,每个开关都在矩阵T中对应两行元素。

仿真模型中的各个测量量可以采用同样的方法组织输出矩阵P。既不是状态也未被测量的电气量将不会出现在矩阵[T;P]中,因此矩阵[T;P]的行数一般情况下是小于矩阵[A;B]的,这也是重写电路方程的意义。

最终状态空间形式的电路方程为

式中,y为Nm个测量量对应的输出向量;上标n+1为当前仿真步长;n为上一仿真步长。矩阵[T;P]的行数Ntr为Nd+2Ns+Nm,列数Ntc为Nd+Ns+Nu。

得到式(7)后,仿真的迭代计算转为矩阵[T;P]与向量之间的矩阵向量乘(MatrixVectorMultipli-cation,MVM)运算。DP和MAC是两种最常见的实现MVM运算的单元,它们的结构示意图如图1所示。

图1DP与MAC的结构示意图

Fig.1StructurediagramsofDPandMAC

理论上,DP拥有更大的并行度,不过有限的FPGA资源与变化的矩阵规模使得它很难达到理论上的并行度。此外,DP加法树复杂的二叉树结构不仅引入了延迟,可配置性还比较差。如Opal-RT的FPGA实时仿真解算器eHS,它的底层就是拥有8个乘法器的DP单元(DP8)[30]。这种情况下,即使电路规模只有11阶,也必须使用两个DP8单元。

相比之下,MAC自身相对独立的逻辑设计赋予了它极强的可拓展性。配合简单的控制逻辑,它很容易实现参数化配置。MAC的这些特点为根据仿真规模、资源数量、速度要求等因素灵活配置MAC单元的数量提供了可能,也是本文选择它完成MVM运算的原因。

本文设计的FPGA实时仿真解算器通用框架如图2所示。整个框架分为离线预处理、在线计算两个部分,离线部分为在线部分提供Nd、Ns和Nu等参数与计算数据{T;P},在线部分负责更新状态与测量量y。

图2解算器的通用框架

Fig.2Generalframeworkoftheproposedsolver

2.1.1离线部分

离线部分中,通过电路分析和方程重写得到更适合实时计算的电路方程;数据类型转换将Matlab默认的双精度浮点数转为IEEE-754标准下的单精度浮点数;ROM初始化文件为在线的MVM运算提供计算数据。本文在Matlab环境下,通过编写脚本完成上述所有离线预处理过程。

在具体实现时,首先,调用power_analyze命令生成Simulink模型的网表文件。该文件包含了电路的元器件参数与节点支路编号等信息。其次,利用这些信息按照FAMNM的规则组织电路的节点方程,并按照算法1的流程组织矩阵[T;P]。最后,根据参数Ncyc将数据类型转换后的矩阵[T;P]划为Ncyc个大小相同的分块,作为ROM的初始化数据{T;P}。其中,Ncyc为解算器中每个MAC单元的复用次数。

本文组织{T;P}的方法为:分块矩阵内部各行元素并行计算、不同分块矩阵之间串行计算。这样解算器中MAC单元的数量Nmac就等于各分块矩阵的行数Nbr。

式中,ceil(·)为向上取整函数。矩阵分块缺少的行填零补充,ROM初始化数据组织方式如图3所示。Ncyc=1时,矩阵[T;P]的所有行全部并行,此时解算器达到它的最大并行度。

考虑到多个仿真工况间的切换,以及提高存储资源的利用率,在生成计算数据时可以准备多组{T;P},并将数据拼接后再写入同一个初始化文件中。

图3ROM初始化数据组织方式

Fig.3OrganizationofROMinitializationdata

以图3为例,初始化数据{T;P}中首地址的全零行是解算器异步复位时的数据,从地址1到地址Nbr的每一个地址都写入第1个分块矩阵中的一列数据,从地址Nbr+1开始写入第2个分块的数据。{T;P}的总地址深度为NcycNbr+1。如果仿真模型有多个工况,如断路或者短路故障,将它们对应的{T;P}从地址NcycNbr+1接着写入,仿真时通过改变ROM读地址的偏移量切换工况。

由于Xilinx的BRAM资源一般以18K、36K为单位进行组合,最大位宽分别是36位、72位[31]。矩阵元素拼接如图4所示,9个32位的数据单独存储时需要9个18K的BRAM,如果将9个数拼接成一个位宽为288的数据,此时存储将只需要8个18K的BRAM,节省了12.5%的BRAM资源。因此,通用解算器在离线预处理时将矩阵元素拼接成大位宽数据后再存储。

图4矩阵元素拼接

Fig.4Splicingofmatrixelements

预处理程序默认只生成一个ROM初始化文件。如果分块矩阵的行数Nbr太大,这时就需要两个或者更多的ROM以及多个初始化文件。以Xilinx的BlockMemoryIP核为例,它支持的最大ROM位宽为4608位,对应144个单精度浮点数[31],即单个ROM初始化文件支持的最大Nbr为144。

2.1.2在线部分

浮定点转换(FP2FX)、数模转换(DAC)的实现比较容易。基于MAC的MVM运算,它的数学原理虽然简单,但其FPGA程序设计却直接决定解算器的性能。向量中ih_d、u的更新直接按照式(7)进行,比较特殊的是ih_s的更新。由于xn+1中既有开关电压也有开关电流,ih_s需要根据开关的通断状态确定。记某个开关的电压、电流分别为vs、is,开关的通断状态为s(s=1,导通;s=0,关断),那么其历史电流源is_h可以表示为

因此,更新开关历史电流源首先要更新开关状态。

仿真中,全控型开关器件的状态由当前步长的开关信号g控制,但是不控型和半控型开关器件的状态还依赖开关上一步长的状态、电压和电流。如二极管的开关状态[9]表达式为

同样地,如果将常用的IGBT反并联二极管模块当作一个整体,它的开关状态[9]为

(11)

在线部分的四个环节中,更新只是简单的选择判断逻辑、FP2FX利用厂家提供的IP核实现、DAC直接采用TI公司的软硬件解决方案,只有MVM运算比较复杂。为此,本文提出一种新的浮点累加方法,用于构建以FPMAC为基本计算单元的MVM运算架构,FPMAC单元与MVM运算整体架构如图5所示。

2.2.1FPMAC单元

浮点运算的硬件复杂度比较高,尤其是FPMAC中的浮点累加计算,累加结果要经历取补、对阶、移位对齐等步骤才能再次累加,往往是整个硬件电路的性能瓶颈[32]。

为了提高浮点累加的速度,文献[33]通过插入寄存器的方法减短关键路径,但是反馈的累加结果在流水线结构中会引发“数据竞争”。还有文献[15,34]将浮点数转为定点数降低累加的难度,不过定点数动态表示范围远不如浮点数广。由文献[32]提出、文献[35-36]优化的方法简化了浮点累加中移位对齐步骤的实现过程,并被用于Opal-RT的eHS解算器,但它对齐前的预处理过程仍有速度瓶颈。

本文通过双向移位对齐的方法实现低延迟的单周期浮点累加。在图5中,累加结果rfd反馈后直接进入累加器,只有符号数乘法的乘积rp根据对阶模块提供的结果进行移位对齐。若乘积的指数大,乘积rp左移;若累加结果的指数大,乘积rp右移。因为对齐仅由乘积rp双向移位完成,浮点累加的关键路径被进一步缩短,最终以极低的延迟实现单周期浮点累加。

图5FPMAC单元与MVM运算整体架构

Fig.5OverallstructureofFPMACunitsandMVMoperations

双向移位对齐的不足在于它使乘积rp的位宽增加了一半,后续累加、标准化等模块的位宽也随之增加。不过这些模块的逻辑比较简单,增加的位宽对解算器资源消耗的影响有限。

FPMAC除了浮点累加,还有符号数并行乘法和标准化两个步骤。符号数乘法通过乘法器IP核实现;标准化(包括前零预测)的原理与实现方法可见文献[37]。整个FPMAC单元采用深度流水线设计,输入输出延迟为10个节拍。图中标出了各模块的执行延迟,寄存器Reg.延迟多个节拍是为了数据同步。如果FPMAC单元的流水线启动延迟Nsp个节拍,那么单个仿真步长的总节拍数Ntp可以表示为

MVM运算环节中FPMAC单元的数量根据离线环节提供的仿真参数自动适配。每个FPMAC单元的输入为a和b、输出为c,不同FPMAC单元间相互并行。整个MVM运算的输入除了初始化数据{T;P},还包括Ncyc和Nx两个控制参数,其中Nx为向量的维数(Nx=Ntc)。图5中,下标“s”、“e”和“m”分别对应IEEE-754标准中浮点数的符号、指数和尾数[38]。

2.2.2控制逻辑

解算器重要的控制逻辑有ROM读地址Addr、累加器清零信号Acc_clr、FPMAC输出使能信号Output_en。主计数器CNT从1~Ntp循环计数,整个解算器的控制逻辑根据它的计数值设计。

以图5中第i个FPMAC单元为例,ROM读操作的典型时序如图6所示。ROM的地址与数据之间的延迟为2个节拍,由于地址提前了一个节拍赋值,ROM实际读延迟只有一个节拍。结合FPMAC单元10个节拍的延迟,整个解算器流水线启动延迟共11个节拍(Nsp=11)。CNT计数值达到NcycNx后,ROM的地址被重置为0,a、b也同步为0;CNT计数值达到Ntp后,ROM地址开始为下一步长重新赋值。

图7为累加器清零信号Acc_clr的典型时序。由图5可知,新数据经历6个节拍到达累加器。当CNT的计数值在6~NcycNx+5之间时,子计数器cnt开始Ncyc次1~Nx的循环计数;否则,cnt保持为Nx。每当cnt=1时,Acc_clr置高。

图6ROM读操作典型时序

Fig.6TypicaltimingofROMreadoperations

图7累加器清零信号典型时序

Fig.7Typicaltimingoftheaccumulatorclearingsignal

FPMAC输出使能信号Output_en的控制逻辑与图7相似。一组新数据经历Nsp个节拍才输出。当CNT的计数值在Nsp~NcycNx+Nsp之间时,cnt在1~Nx间循环计数;否则,cnt保持为Nx。每当cnt=1时,Output_en置高。

本文基于XilinxISE14.7环境完成解算器代码的开发与评估,目标器件为Virtex7xc7vx485t,测试对象为如图8所示的三相两电平桥式变换器电路拓扑。仿真参数见表1,其中3个测量量分别为a相电压电流和a、b两相之间的线电压。

图8三相两电平桥式变换器电路拓扑

Fig.8Three-phasetwo-levelbridgeconverter

解算器根据表1参数自动适配,表2列出了每个环节资源消耗的结果。MVM环节消耗了整个解算器程序86.25%的寄存器资源、94.20%的LUT资源和100%的DSP资源。FP2FX环节将32位单精度浮点数转为Q(10,6)格式的16位定点数,耗时6个节拍。DAC环节采用TI公司的解决方案,数据未列出。

表3是单个FPMAC单元和整个解算器的评估结果。FP2FX环节的代码规模取决于测量量个数,具有不确定性,评估时未将其包括在内。两个评估对象的关键路径都是乘法器IP核,因而它们拥有相同的关键路径延迟和最大时钟频率。在双向移位对齐的作用下,共3级流水线、消耗2个DSP的乘法器IP核,代替了浮点累加成为FPMAC的关键路径,这是FPMAC单元和解算器的最大时钟频率能够达到420.698MHz的关键。

表1变换器仿真参数

Tab.1Simulationparametersoftheconverter

参数数值电路参数独立动态元件数Nd4开关数Ns6独立输入源数Nu1测量量个数Nm3配置参数FPMAC循环次数Ncyc1仿真运行参数[T;P]规模Ntr×Ntc19×11{T;P}规模(Ncyc×Nmac)×Nx(1×19)×11流水线启动延迟节拍数Nsp11单仿真步长总节拍数Ntp22

表2解算器各环节资源消耗

Tab.2Resourceconsumptionofeachstepinthesolver

环节更新MVMFP2FX合计时钟节拍数111617资源消耗Regs.81611621103613473LUTs7002567288227254DSPs046046

表3仿真模型评估结果(Ncyc=1)

Tab.3Evaluationresultsofthesimulationmodel(Ncyc=1)

评估对象FPMAC解算器FPMAC数量Nmac119最大逻辑延迟/ns2.3772.377最大时钟频率/MHz420.698420.698资源消耗(占比)Regs.496(0.08%)10036(1.65%)LUTs1066(0.35%)21508(7.08%)DSPs2(0.07%)38(1.36%)BRAMs1(0.09%)9(1.07%)

解算器的初始化数据共消耗8个36K、1个18K的BRAM,如果矩阵元素不拼接则需要19个18K的BRAM,多消耗2个18K的BRAM。解算器资源消耗基本与它的FPMAC单元数量成正比,证实了MAC可拓展性极强。

3.2.1仿真速度

本文解算器仿真步长Ts为

图8所示三相两电平桥式变换器模型的Ntp=22,对应的最小Ts=55ns。常见三相多电平拓扑接阻感负载时,它们相应的最小Ts见表4。结果显示,对于NPC/H九电平、五电平MMC这些较大规模的拓扑,最小Ts在55~200ns之间;对于一般规模的拓扑,最小Ts通常约在100ns级。

表4常见多电平拓扑的最小Ts

Tab.4MinimumvaluesofTsofseveralmulti-leveltopologies(单位:ns)

电路拓扑开关LCeHS本文两电平桥式6521055三电平NPC18524585五电平NPC/H365300130五电平MMC4833525230九电平NPC/H725470220

表4同时列出了Opal-RTeHS解算器对上述拓扑预估的最小Ts。可以发现,eHS的最小Ts是本文解算器的2.136~3.818倍,拓扑规模越小,差别越大。根据eHS解算器手册,其最大仿真频率为200MHz,最小Ts=200ns(同样是基于xc7vx485t型芯片)[39]。与本文解算器400MHz的仿真速度相比,eHS解算器的最小Ts理应是本文解算的2倍。实际结果普遍大于2倍的原因如1.3节所述:eHS解算器底层计算单元是DP8。模型规模越小,DP8单元利用率越低,最小Ts差距也就越大。

3.2.2仿真规模

由于MAC延迟相对固定、资源消耗基本呈线性,本节分别以仿真步长和FPGA硬件资源为约束条件预估解算器的仿真规模,即

一方面,fs=400MHz时,解算器1ms仿真步长可以串行处理400个数据,对应矩阵[T;P]的列数或者向量的维数为400;另一方面,考虑到解算器消耗最多的资源是LUT以及资源裕度,以70%的LUT资源评估仿真规模。这些LUT资源可以支持175个FPMAC单元,即解算器最多支持矩阵的175行数据全并行计算。

式(15)为本文所提解算器仿真步长Ts与仿真规模之间的关系。基于所有指标能够同时到达最大值这一假设,本文预估了所提解算器的仿真规模,与文献[39]给出的Opal-RTeHS解算器仿真规模对比见表5。

表5两种解算器仿真规模对比

Tab.5Comparisonsofsimulationscaleoftwosolvers

解算器Ts/msNuNmNsNdeHS4.8012812814456本文所提4.8016612825856

相同条件下,本文解算器支持的输入源数量Nu增加了29.69%,开关数量Ns增加了79.17%。另外,eHS通过四种不同规模的计算引擎适配任意规模的电路拓扑[39],资源利用率低、可配置性不好。本文解算器得益于MAC单元的灵活性,能够根据仿真规模与仿真需求,配置并生成定制化的计算引擎,资源利用率高、灵活性强。

图9为仿真测试的硬件平台,包括:Xilinx公司的VC707评估板、TI公司的DAC3484数模转换模块以及配套的FMC-DAC转接板。VC707评估板搭载了一块Virtex7xc7vx485t型的FPGA芯片,DAC3484评估模块拥有4通道、16位分辨率和1.25GSPS的转换能力。同时,还有一台Opal-RTOP5700仿真机,用于比较eHS解算器与本文解算器的仿真结果。

图9硬件平台

Fig.9Hardwareplatform

4.2.1算例一:三相两电平桥式变换器

为了验证解算器通用框架与FPGA程序的正确性,根据表6所列电气参数对两电平桥式变换器进行以下三种仿真:①变换器S函数模型在Matlab中的离线仿真,数据为双精度浮点格式;②变换器模型在本文所提解算器中的实时仿真;③变换器模型在eHS解算器中的实时仿真。两种实时仿真的数据都是单精度浮点格式。为了排除开关建模方法本身以及不同仿真步长对仿真结果的影响,三种仿真都基于LC等效开关模型,开关等效导纳设为1S,仿真步长设为1ms。

表6两电平桥式变换器电气参数

Tab.6Electricalparametersoftwo-levelbridgeconverter

参数数值直流电压Udc/V240串联电阻r/mW1电容C1,C2/mF4电感La,Lb,Lc/mH2电阻Ra,Rb,Rc/W3调制波频率/Hz50开关频率/kHz10

图10两电平桥式变换器a相电压波形

Fig.10Voltagewaveformsofphaseafromtwo-levelbridgeconverter

图11是两电平桥式变换器a相电流波形。三种仿真波形总体上保持一致,但从放大的细节可以看出:与离线仿真相比,eHS解算器的电流纹波更小,最大误差率仅为1.87%,而本文解算器的电流最大误差约为1.3A的,最大误差率达到了3.47%。原因可能有两个方面:①两种解算器的FPGA代码截断浮点计算结果的位宽不同;②两种解算器所在硬件平台的DAC电路设计不同。

为了验证本文解算器的多工况仿真能力,在Ra=Rb=Rc=3W的条件下,增加了电阻Ra=Rb=Rc=5W的工况。离线生成ROM初始化数据时,{T;P}里包含Ra,Rb,Rc为3W和10W两种工况的计算数据。仿真时,目前是通过定时器触发ROM读地址偏移量的变更,进而实现仿真工况的切换。

图11两电平桥式变换器a相电流波形

Fig.11Currentwaveformsofphaseafromtwo-levelbridgeconverter

工况切换时的a相电流波形如图12所示。可以发现,实时仿真的波形能够随着工况切换而正确变化。切换瞬间,电流发生突变,实时仿真的响应存在较小的波动。约1.2ms后,实时仿真与离线仿真的波形再次贴合。测试结果证实了解算器具备在高开关频率下进行不同工况小步长实时仿真的能力。

图12工况切换时的a相电流波形

Fig.12Currentwaveformsofphaseawhenworkingconditionswitching

4.2.2算例二:三相三电平中点钳位变换器

图13NPC变换器a相电压波形

Fig.13VoltagewaveformsofphaseafromNPCconverter

图14NPC变换器a相电流波形

Fig.14CurrentwaveformsofphaseafromNPCconverter

本文提出并实现了一款基于FPGA的电力电子系统EMT实时仿真通用解算器。该解算器以高速FPMAC为基本计算单元,能够达到400MHz的运行速度、100ns级的仿真步长并保持较高的仿真精度,具有通用性强、自动化程度高、配置灵活等特点。在相同硬件条件下,它的仿真速度、仿真规模、资源利用率和使用灵活性都比Opal-RT公司的eHS解算器有优势。

后续除了通过更多算例测试解算器的性能外,还将从以下方面优化完善解算器的功能:消除LC等效开关模型的过脉冲、标幺化解算器数值、实现在线调参以及可将程序移植到国产FPGA芯片上等。

附录

算法1:状态矩阵T组织流程输入:x,A,B,节点对编号(j,k),支路编号l输出:Tfor1≤i≤Ndifx(i)对应电容元件T(i)←A(j)–A(k);else//x(i)对应电感元件T(i)←B(l);endifendforforNd<i≤Nd+NsT(2i-Nd-1)←A(j)–A(k);//对应开关电压T(2i-Nd)←B(l);//对应开关电流endfor

参考文献

[1]孙鹏琨,葛琼璇,王晓新,等.基于硬件在环实时仿真平台的高速磁悬浮列车牵引控制策略[J].电工技术学报,2020,35(16):3426-3435.

SunPengkun,GeQiongxuan,WangXiaoxin,etal.Tractioncontrolstrategyofhigh-speedmaglevtrainbasedonhardware-in-the-loopreal-timesimulationplatform[J].TransactionsofChinaElectrotechnicalSociety,2020,35(16):3426-3435.

[2]王成山,李鹏,王立伟.电力系统电磁暂态仿真算法研究进展[J].电力系统自动化,2009,33(7):97-103.

WangChengshan,LiPeng,WangLiwei.Progressesonalgorithmofelectromagnetictransientsimulationforelectricpowersystem[J].AutomationofElectricPowerSystems,2009,33(7):97-103.

[3]王潇,张炳达,乔平.一种面向微电网实时仿真的分块分层并行算法[J].电工技术学报,2017,32(7):104-111.

WangXiao,ZhangBingda,QiaoPing.Ablockhierarchicalparallelmethodforreal-timesimulationofmicrogrid[J].TransactionsofChinaElectro-technicalSociety,2017,32(7):104-111.

[4]ChalangarH,Ould-BachirT,SheshyekaniK,etal.Methodsfortheaccuratereal-timesimulationofhigh-frequencypowerconverters[J].IEEETransa-ctionsonIndustrialElectronics,2022,69(9):9613-9623.

[5]MahseredjianJ,DinavahiV,MartinezJA.Simulationtoolsforelectromagnetictransientsinpowersystems:overviewandchallenges[J].IEEETransactionsonPowerDelivery,2009,24(3):1657-1669.

[6]郝琦,葛兴来,宋文胜,等.电力牵引传动系统微秒级硬件在环实时仿真[J].电工技术学报,2016,31(8):189-198.

HaoQi,GeXinglai,SongWensheng,etal.Micro-secondhardware-in-the-loopreal-timesimulationofelectrictractiondrivesystem[J].TransactionsofChinaElectrotechnicalSociety,2016,31(8):189-198.

[7]朱建鑫,胡海兵,陆道荣,等.应用于级联STATCOM的高精度低成本全FPGA实时仿真模型研究[J].电工技术学报,2019,34(4):777-785.

ZhuJianxin,HuHaibing,LuDaorong,etal.TheresearchonfullyFPGA-basedreal-timesimulationwithhighfidelityandlowcostforthecascadedSTATCOM[J].TransactionsofChinaElectrotech-nicalSociety,2019,34(4):777-785.

[8]李浩洋,李泽,郭源博,等.考虑开关管开路故障的三电平STATCOM建模与硬件在回路实时仿真[J].电工技术学报,2019,34(3):552-561.

LiHaoyang,LiZe,GuoYuanbo,etal.Modelingandhardware-in-the-loopreal-timesimulationofthree-levelSTATCOMconsideringswitchopen-circuitfaults[J].TransactionsofChinaElectrotechnicalSociety,2019,34(3):552-561.

[9]DufourC,CenseS,Ould-BachirT,etal.General-purposereconfigurablelow-latencyelectriccircuitandmotordrivesolveronFPGA[C]//AnnualCon-ferenceonIEEEIndustrialElectronicsSociety,Montreal,2012:3073-3081.

[10]BachirTO,DufourC,DavidJP,etal.Floating-pointenginesfortheFPGA-basedreal-timesimulationofpowerelectroniccircuits[C]//InternationalConferenceonPowerSystemsTransients(IPST),Delft,2011:1-7.

[11]OuldBachirT,DufourC,BélangerJ,etal.Afullyauto-matedreconfigurablecalculationenginededi-catedtothereal-timesimulationofhighswitchingfrequencypowerelectroniccircuits[J].MathematicsandComputersinSimulation,2013,91:167-177.

[12]RazzaghiR,PaoloneM,RachidiF.AgeneralpurposeFPGA-basedreal-timesimulatorforpowersystemsapplications[C]//IEEE/PESInnovativeSmartGridTechnologiesEurope,Istanbul,2014:1-5.

[13]RazzaghiR,MitjansM,RachidiF,etal.AnautomatedFPGAreal-timesimulatorforpowerelectronicsandpowersystemselectromagnetictransientapplications[J].ElectricPowerSystemsResearch,2016,141:147-156.

[14]王成山,丁承第,李鹏,等.基于FPGA的配电网暂态实时仿真研究(一):功能模块实现[J].中国电机工程学报,2014,34(1):161-167.

WangChengshan,DingChengdi,LiPeng,etal.ResearchonFPGA-basedtransientreal-timesimu-lationofdistributionnetwork,partⅠ:realizationoffunctionalmodules[J].ProceedingsoftheCSEE,2014,34(1):161-167.

[15]王成山,丁承第,李鹏,等.基于FPGA的配电网暂态实时仿真研究(二):系统架构与算例验证[J].中国电机工程学报,2014,34(4):628-634.

WangChengshan,DingChengdi,LiPeng,etal.Real-timetransientsimulationfordistributionsystemsbasedonFPGA,partII:systemarchitectureandalgorithmverification[J].ProceedingsoftheCSEE,2014,34(4):628-634.

[16]WangZhiying,ZengFanpeng,LiPeng,etal.KernelsolverdesignofFPGA-basedreal-timesimulatorforactivedistributionnetworks[J].IEEEAccess,2018,6(1):29146-29157.

[17]MajstorovicD,CelanovicI,TeslicND,etal.Ultralow-latencyhardware-in-the-loopplatformforrapidvalidationofpowerelectronicsdesigns[J].IEEETransactionsonIndustrialElectronics,2011,58(10):4708-4716.

[18]PejovicP,MaksimovicD.Amethodforfasttime-domainsimulationofnetworkswithswitches[J].IEEETransactionsonPowerElectronics,1994,9(4):449-456.

[19]DagbagiM,HemdaniA,IdkhajineL,etal.ADC-basedembeddedreal-timesimulatorofapowercon-verterimplementedinalow-costFPGA:applicationtoafault-tolerantcontrolofagrid-connectedvoltage-sourcerectifier[J].IEEETransactionsonIndustrialElectronics,2016,63(2):1179-1190.

[20]GuoXizheng,TangYiguo,WuMingkang,etal.FPGA-basedhardware-in-the-loopreal-timesimu-lationimplementationforhigh-speedtrainelectricaltractionsystem[J].IETElectricPowerApplications,2020,14(5):850-858.

[21]穆清,周孝信,王祥旭,等.面向实时仿真的小步长开关误差分析和参数设置[J].中国电机工程学报,2013,33(31):120-129,15.

MuQing,ZhouXiaoxin,WangXiangxu,etal.Small-stepswitchingerroranalysisandparametersettingforreal-timesimulation[J].ProceedingsoftheCSEE,2013,33(31):120-129,15.

[22]DufourC.Methodandsystemforreducingpowerlossesandstate-overshootsinsimulatorsforswitchedpowerelectroniccircuit:US,9665672[P].2017-05-30.

[23]LiZirun,XuJin,WangKeyou,etal.Adiscretesmall-stepsynthesisreal-timesimulationmethodforpowerconverters[J].IEEETransactionsonIndustrialElectronics,2022,69(4):3667-3676.

[24]DommelHW.Digitalcomputersolutionofelectro-magnetictransientsinsingleandmultiphasenet-works[J].IEEETransactionsonPowerApparatusandSystems,1969,PAS-88(4):388-399.

[25]HoCW,RuehliA,BrennanP.Themodifiednodalapproachtonetworkanalysis[J].IEEETransactionsonCircuitsandSystems,1975,22(6):504-509.

[26]MahseredjianJ.Computationofpowersystemtransients:overviewandchallenges[C]//IEEEPowerEngineeringSocietyGeneralMeeting,Tampa,2007:1-7.

[27]MartiJR,LinJ.SuppressionofnumericaloscillationsintheEMTP[J].IEEEPowerEngineeringReview,1989,9(5):71-72.

[28]徐晋.通用电力电子实时仿真方法研究及应用[D].上海:上海交通大学,2019.

[29]Ould-BachirT,DufourC,BélangerJ,etal.Effectivefloating-pointcalculationenginesintendedfortheFPGA-basedHILsimulation[C]//InternationalSym-posiumonIndustrialElectronics,Hangzhou,2012:1363-1368.

[30]Ould-BachirT,MerdassiA,CenseS,etal.FPGA-basedreal-timesimulationofaPSIMmodel:anindirectmatrixconvertercasestudy[C]//AnnualCon-ferenceoftheIEEEIndustrialElectronicsSociety,Yokohama,2016:3336-3340.

[32]VangalSR,HoskoteYV,BorkarNY,etal.A6.2-GFlopsfloating-pointmultiply-accumulatorwithconditionalnormalization[J].IEEEJournalofSolidStateCircuits,2006,41(10):2314-2323.

[33]ZhuoLing,MorrisGR,PrasannaVK.High-performancereductioncircuitsusingdeeplypipelinedoperatorsonFPGAs[J].IEEETransactionsonParallelandDistributedSystems,2007,18(10):1377-1392.

[34]ChenYuan,DinavahiV.Aniterativereal-timenon-linearelectromagnetictransientsolveronFPGA[J].IEEETransactionsonIndustrialElectronics,2011,58(6):2547-2555.

[35]Ould-BachirT,DavidJP.Performingfloating-pointaccumulationonamodernFPGAinsingleanddoubleprecision[C]//IEEEAnnualInternationalSymposiumonField-ProgrammableCustomComputingMachines,Charlotte,2010:105-108.

[36]Ould-BachirT,DavidJP.Self-alignmentschemesfortheimplementationofaddition-relatedfloating-pointoperators[J].ACMTransactionsonReconfigurableTechnologyandSystems,2013,6(1):1-21.

[37]OklobdzijaVG.Analgorithmicandnoveldesignofaleadingzerodetectorcircuit:comparisonwithlogicsynthesis[J].IEEETransactionsonVeryLargeScaleIntegration(VLSI)Systems,1994,2(1):124-128.

[38]IEEEStandards754-2008.IEEEstandardforfloating-pointarithmetic[S].NewYork:IEEEComputerSocietyMicroprocessStandardsCommittee,2008.

ZhouBinWangGuangsenLiWeichaoWangZhiweiJieGuisheng

(NationalKeyLaboratoryforVesselIntegratedPowerSystemTechnologyNavalUniversityofEngineeringWuhan430033China)

AbstractAsthefrequencyofpowerelectronicswitchesincreases,thetraditionalelectromagnetictransient(EMT)real-timesimulationbasedonCPUsfailstodescribethehigh-frequencycharacteristicsofswitchesaccurately.IthasbecomeatrendtotakeFPGAsasthehardwareplatformsforreal-timesimulation.However,thefollowingchallengesexist:(1)thehighprogrammingthresholdandlongdevelopmentcyclemakeitdifficulttoconductareal-timesimulationbasedonFPGAs;(2)itishardtoensurethereal-timeperformanceofsimulationwhilecompletinghighcomplexityandlarge-scaleiterativecalculation.Therefore,thispaperproposesareal-timeEMTsimulationuniversalsolverforpowerelectronicsystemsbasedonFPGAs.

Thefollowingconclusionscanbedrawnfromthetheoreticalanalysisandsimulations.TheproposedgeneralsolverbasedonFPGAs,withhigh-speedMACasthebasiccomputingunit,canachievearunningspeedof400MHz,asimulationstepof100ns,andmaintainahighsimulationaccuracy.Ithasthecharacteristicsofstrongversatility,highautomation,andflexibleconfiguration.Underthesamehardwareconditions,itssimulationspeed,simulationscale,resourceutilization,anduseflexibilityareallsuperiortotheeHSsolverofOPAL-RT.

keywords:Powerelectronicsystems,FPGAreal-timesimulation,generalsolver,floating-pointmultiply-accumulate

国防科技重点实验室资助项目(6142217200305)。

收稿日期2022-05-26

改稿日期2022-09-20

DOI:10.19595/j.cnki.1000-6753.tces.220918

中图分类号:TM921

作者简介

周斌男,1994年生,博士研究生,研究方向为电力电子系统的实时仿真建模与解算。E-mail:zhoubin5637@163.com

李卫超男,1982年生,研究员,博士生导师,研究方向为大功率电能变换装置、电机控制。E-mail:liweichao3721@126.com(通信作者)

THE END
1.机器学习:在线学习和离线学习区别机器学习中的在线学习(Online Learning)和离线学习(Offline Learning)是两种不同的学习方式,它们在数据处理和模型更新方面有着明显的区别。以下是它们的主要区别: 数据获取方式: 在线学习:在在线学习中,模型是不断地从数据流中接收新的样本并进行学习。这意味着模型会随着时间的推移不断更新,以适应新的数据。 https://blog.csdn.net/weixin_41194129/article/details/132998721
2.在线设备和离线设备的区别在线设备是可以搜索的出来的。离线设备指的是处于不在线的设备,也就是说没有登录的设备,离线设备可能https://edu.iask.sina.com.cn/jy/lNn2tLLRZf.html
3.最后纪元离线和在线区别是什么最后纪元离线在线有什么不同在离线版里玩家是不能喝其他玩家进行组队或者交易的,只能一个人进行单机游戏。而在线版的玩家就可以邀请其他玩家一起组队冒险,还可以在集市里与其他玩家进行交易。接下来九游小编就给大家带来最后纪元离线在线有什么不同。 最后纪元离线和在线区别是什么? 能不能联机的区别。https://www.9game.cn/news/9901357.html
4.双人成行离线和在线有什么区别双人成行二号玩家加入方法3、游戏的玩法不同。双人成行离线玩法需要玩家一个使用键盘,另一个使用摇杆才可以玩。而双人成行在线则不需要区分,两者都可以使用键盘。 以上就是双人成行双人成行离线和在线的区别以及二号玩家加入的方法了,想要了解更多相关攻略的小伙伴可以持续关注游侠网,这里每天会为大家推送最新最全的攻略,一定不要错过哦。https://gl.ali213.net/html/2022-6/860745.html
5.案例9:使用计算—离线和在线使用的主要区别在离线仿真与在线仿真中递归计算(计算中某个输出位号作为自身的函数)的行为是不一样的。行为的不同是因为嵌入离线仿真和嵌入在线系统的设计差异导致的。本教程的目的是着重介绍这一差异。 ?在离线仿真器中,k时刻的值被用于初始化k+1时刻的仿真。如果你有计算[A] =[A]+1且[A]=0,那么开始时产生的顺序是1https://www.jianshu.com/p/28da66d9eafb
6.离线LowE玻璃和在线LowE玻璃两者概念有何不同?知识库在线Low-E玻璃是在浮法玻璃生产线上,采用专用的设备,通过化学气相沉积工艺和专用材料在浮法生产线上的玻璃带表面形成一层具有低辐射性能的功能膜。这种工艺生产的Low-E玻璃称为在线Low-E玻璃,其膜层材料为半导体氧化物,产品颜色仅有冷灰、无色透明等少数品种。离线Low-E玻璃采用专用的真空磁控溅射镀膜设备和工艺技术http://www.alwindoor.com/zsk/ask.asp?id=13323
7.在线式巡更和离线式巡更的不同之处二.离线式巡更:顾名思义此系统无需布线,只要将巡更巡检点安装在巡逻位置,巡逻人员手持巡更巡检器到每一个巡更巡检点采集信息后,将信息通过数据线传输给计算机,就可以显示整个巡逻巡检过程(如需要再由打印机打印,就形成一份完整的巡逻巡检考察报告)。 相对于在线式电子巡更巡检系统离线式电子巡更巡检系统的缺点是不能http://hkjum897140.51sole.com/companynewsdetail_161449825.htm
8.由于当前在线组态数据与离线组态数据不同,因此无诊断数据可用新建的程序文件,里面没程序的,正在组态,用的博图V15的,除了主CPU1511正常的,其他的所有模块包括PS模块都显示由于当前在线组态数据与离线组态数据不同,因此无诊断数据可用,请教一下什么原因 【方案】服务智能物流,华北工控RPC-610M整机支持自动分拣系统应用 只看该作者 | 赞[0] | 踩[1] | 引用 | 回复 | http://bbs.gkong.com/archive.aspx?id=477495
9.在线LowE玻璃和离线Low在线Low-E玻璃和离线Low-E玻璃由于膜层不同、工艺不同等原因,使两者的产品性能参数不尽相同,甚至存在较大差异。下面按光学性能、节能特性、可加工性、成本构成、电磁屏蔽、品种颜色可选择性等几方面进行对比说明。 光学性能是一项主要性能,可以说光学性能决定了Low-E玻璃效能好坏及颜色的不同。对Low-E玻璃而言,无论https://www.douban.com/note/757012330/
10.云盘扩容,离线扩容和在线扩容有什么区别,扩容时需要关机吗?阿里云提供了两种方式进行云盘扩容:在线扩容和离线扩容。在线扩容的优点在于扩容完成后无需重启实例,这https://developer.aliyun.com/ask/570725
11.在对齐AI时,为什么在线方法总是优于离线方法?澎湃号·湃客该团队采用了与 Gao et al. (2023) 类似的设置,基于一组开源数据集进行了实验,结果表明:在同等的优化预算(相对于 SFT 策略的 KL 散度)下,在线算法的性能表现通常优于离线算法。 图1 给出了在线和离线算法在四个不同的开源数据集上表现出的 KL 散度与策略性能之间的权衡。图中的每个数据点代表了在训练过程https://www.thepaper.cn/newsDetail_forward_27434433
12.电工技能:“UPS电源和EPS电源”的工作原理及两者之间的区别!3、后备式和在线式UPS工作原理 1)后备式UPS(离线式UPS) 在市电正常时由市电直接向设备供电,当市电断开时由蓄电池逆变供电。 其特点是:结构简单,体积小,成本低,但输入电压范围窄,有切换时间,不适用于对电源质量要求高的设备,通常用于个人计算机。 2)在线互动式UPS https://www.swpu.edu.cn/eelab/info/1090/2326.htm
13.微信在线不在线的区别是什么?有什么方法知道好友是否在线?几年前,我们常用的聊天软件是qq,而现在,微信的风头几乎已经改过了qq。微信在很多功能方面和qq类似,不过,也有些不一样的功能。比如,微信在线与不在线,很多人都不知道这两者有什么区别,下面,我们来看看具体的情况。 其实微信是不能看好友在不在线的,这是微信的一个特点,就是没有在线与离线。也就是说,在线与不https://www.kaitao.cn/article/20180906115708.htm
14.蚂蚁金服核心技术:百亿特征实时推荐算法揭秘通过真实线上数据仿真,它能接近离线频次过滤的效果,其λ是随每次特征进入时动态计算的。它的缺陷是: 当t越小时,事件发生在t内的次数的variance越大,所以会以一定概率误加或丢弃特征。 未来总的训练步数T在在线学习中是未知的。 频次过滤与优化器相分离,导致不能获得优化器的统计信息。 https://maimai.cn/article/detail?fid=1010621115&efid=mIQCHnkj0zjxlpygUmo5mg