库伦和密立根电荷量的区别(小议MILSILPIL)(1)

作者:JACK(来源:IN4汽车人)

在基于模型的软件工程(MBSE)中,我们经常会谈到MIL/SIL/PIL和HIL,很多新入门者常常会搞混它们的含义,笔者撰写本文的目的是概要性的介绍XIL之间的区别与联系,尽我所能把它们讲清楚。

术语定义:

几个常见问题:

(1) 大部分狭义的的MIL(End2End Test)是需要带被控对象模型的(也有例外,如上文讲的某功能知识控制一个灯的开关,大没有必要建一个灯泡的模型),广义的MIL一般不care被控对象模型;

  • 是不是MIL一定要用浮点数,SIL一定要用定点数?

  • (一) MIL

    MIL就是模型在环,通俗一点理解就是对模型在模型的开发环境下(如simulink)进行仿真,通过输入一系列的测试用例,验证模型是否满足了设计的功能需求。MIL是所有测试中最关键的,因为MIL的test accept criterion必须源于功能需求,没有其它的东西可以参考。而SIL/PIL的测试用例往往都是借用MIL的测试用例,一旦在MIL这个阶段的使用了错误测试用例,这个Bug很有可能会最终流出去,即便所有的测试都通过了。

    a) 狭义的MIL

    狭义的MIL一般指针对带被控对象模型,实现整个控制功能的模型进行End to End的测试。

    如下图,电机控制的MIL模型有MotorController和PlantModel两个子模型组成:

    库伦和密立根电荷量的区别(小议MILSILPIL)(2)

    PlantModel又包含:

    库伦和密立根电荷量的区别(小议MILSILPIL)(3)

    库伦和密立根电荷量的区别(小议MILSILPIL)(4)

    运行simulink仿真,比如我们设定电池电压13V,电机转速800rpm,指令力矩2Nm,在scope中我们电机输出了较理想的正弦波,输出力矩也稳定在2Nm左右,如下:

    库伦和密立根电荷量的区别(小议MILSILPIL)(5)

    做到这一步,MIL就算结束了吗?非也非也,MIL还有一个重要的任务是为SIL和PIL的testcase收集test vectors(TV)。仿真的侧重点在于功能是否已正确实现,而MIL在simulation的基础上,还要把所有的输入输出保存起来作为测试向量将来给SIL/PIL使用。

    以MotorController为被控对象,让我们看看下表:

    库伦和密立根电荷量的区别(小议MILSILPIL)(6)

    b) 广义的MIL

    在软件测试领域还有一个很重要的概念是测试覆盖度,对于ASIL级别比较高的产品,一般都需要MCDC测试覆盖度100%,而如果模型比较复杂的话,往往前文所述的狭义的MIL很难达到100%的测试覆盖度,因此我们还需要对某一个具体的子功能模块特别设置一些测试用例来测试,在这种情况下,往往不使用PlantModel。

    (二) SIL

    SIL是一种等效性测试,测试的目的是验证代码与控制模型在所有功能上是完全一致的。其基本原则一般是使用与MIL完全相同的测试用例输入,将MIL的测试输出与SIL的测试输出进行对比,考察二者的偏差是否在可接受的范围之内?

    库伦和密立根电荷量的区别(小议MILSILPIL)(7)

    因此这个测试的目的就决定了带不带被控对象模型并不是那么重要。SIL测试一般都在PC上完成,对代码的编译器一般都是LCC,SDK,MSC等这些。

    至于SIL的实现方法,那真是五花八门多种多样了:

    库伦和密立根电荷量的区别(小议MILSILPIL)(8)

    set_param(model_name, ‘SimulationMode’,’Software-in-the-loop’)

    库伦和密立根电荷量的区别(小议MILSILPIL)(9)

    库伦和密立根电荷量的区别(小议MILSILPIL)(10)

    (三) PIL

    PIL测试与SIL测试的不同在于软件是使用的目标MCU的编译器(Tasking)进行编译链接,也需要运行在目标板上,其基本工作原理如下。

    库伦和密立根电荷量的区别(小议MILSILPIL)(11)

    其测试通过准则是,使用与SIL相同的测试用例输入进行测试时,比较PIL和SIL的输出,如果两者之差在容许范围之内,则测试通过。

    此外,PIL测试还能够测量某个功能模块的程序运行时间、堆栈(系统和用户)使用情况等等如下图,这些数据在所有软件功能模块集成之前对软件CPU Load、软件是否有跑飞的风险都是有非常大的帮助的。

    库伦和密立根电荷量的区别(小议MILSILPIL)(12)

    篇幅所限,本文先写到这里。下一篇将以EPS为例来专题讨论这三个层级的HIL。

    课程上线,关注IND4汽车人下载APP

    《新能源汽车解读及动力构型》

    库伦和密立根电荷量的区别(小议MILSILPIL)(13)

    ,