主要内容

调用 C 库函数

您可以在 Stateflow® 图中通过调用 C 库函数来添加数学运算、三角计算和指数计算,或调用 C 函数。使用 C 语言作为动作语言的图可以调用 C 库函数,而无需使用任何特殊前缀或函数包装器。要在使用 MATLAB® 作为动作语言的图中调用 C 函数,请使用 coder.ceval (Simulink) 函数。有关详细信息,请参阅使用 MATLAB Function 模块集成 C 代码 (Simulink)

要更新图使用的动作语言,请参阅修改图的动作语言

调用 C 库函数

在使用 C 语言作为动作语言的图中,您可以调用以下 C 数学库函数:

  • abs

  • sin

  • cos

  • tan

  • sinh

  • tanh

  • acos

  • atan

  • atan2

  • cosh

  • ceil

  • floor

  • exp

  • fabs

  • fmod

  • labs

  • ldexp

  • log

  • log10

  • pow

  • rand

  • sqrt

当您调用这些函数时,必须使用双精度值,除非所有输入参量显式为单精度。当输入参量不匹配时,图会将输入参量强制转换为预期的数据类型。例如,如果您使用整数作为输入参量调用 sin 函数,图会将该输入参量强制转换为双精度类型的浮点数。

要调用其他 C 库函数,请打开“配置参数”对话框,并在仿真目标窗格中输入适当的 #include 语句,如Configure Custom Code中所述。

注意

当图将 C 库函数的输入参量转换为浮点数时,具有类型为 int64uint64 的参量的函数调用会导致精度损失。

调用 abs 函数

Stateflow 图解释 abs 函数的方式与标准 C 版本的 abs 不同,它按如下方式处理整数和浮点参量:

  • 如果 xint32int64 类型的整数,则标准 C 函数 abs 应用于 x,即 abs(x)

  • 如果 xint16int8 类型的整数,则将标准 C abs 函数应用于转换为 int32 类型整数的 x,即 abs((int32)x)

  • 如果 xdouble 类型的浮点数,则将标准 C 函数 fabs 应用于 x,即 fabs(x)

  • 如果 xsingle 类型的浮点数,则将标准 C 函数 fabs 应用于转换为 double 类型的 x,即 fabs((double)x)

  • 如果 x 是定点数,则将标准 C 函数 fabs 应用于转换为 double 类型的定点数,即 fabs((double) Vx),其中 Vxx 的实际值。

如果您需要使用的 abs 函数像在标准 C 版本函数中那样工作,请将其参量或返回值强制转换为整数类型。有关详细信息,请参阅类型转换运算

注意

如果您在自定义代码中声明一个变量,则在所有情况下都将应用标准 C abs 函数。有关将自定义代码插入图中的说明,请参阅Use Custom C or C++ Code in Stateflow Charts

调用 min 和 max 函数

您可以通过在生成代码的顶部发出以下宏来调用 minmax

#define min(x1,x2) ((x1) > (x2) ? (x2):(x1))
#define max(x1,x2) ((x1) > (x2) ? (x1):(x2))

为了允许与用户创建的名为 min()max() 的图形函数兼容,生成代码中的函数使用名称 <prefix>_min。但是,如果您将 min()max() 图形函数导出到模型中的其他图,则生成代码无法使用函数的修改后名称,因而会发生冲突。为避免这种冲突,请重命名 min()max() 图形函数。

用应用程序实现替换数学库函数

labsrand 之外,您可以更改代码生成器在最终生成代码中实现数学库函数的方式。要执行此操作,请将代码生成器配置为在代码生成期间应用代码替换库 (CRL)。此外,如果您有 Embedded Coder® 许可证,则可以开发自定义 CRL。

有关使用 MathWorks® 提供的 CRL 替换代码的详细信息,请参阅什么是代码替换? (Simulink Coder)代码替换库 (Simulink Coder)。有关开发自定义代码替换库的信息,请参阅什么是代码替换自定义? (Embedded Coder)Code You Can Replace From Simulink Models (Embedded Coder)

调用自定义 C 代码函数

您可以在 Stateflow 图中创建自定义 C 函数,并将其用于仿真和代码生成。调用自定义函数时:

  • 写入函数名称,后跟括号中的参量。

  • 以可选的分号结束函数调用。

  • 使用单引号将参数传递给用户编写的函数。

  • 对文本字符串使用双引号。

C 函数可以返回任何数据类型。有关详细信息,请参阅Configure Custom Code。当您编写访问输入向量的 C 函数时:

  • 使用 sizeof 函数来确定输入向量的长度。

    例如,您的自定义函数可以包含使用 sizeoffor 循环,输入:

    for(i=0; i < sizeof(input); i++) {
    ......
    }
  • 如果您的自定义函数多次使用输入向量长度的值,请在函数中包含指定输入向量长度的输入参数。

    例如,您可以使用 input_length 作为 sum 函数的第二个输入,如下所示:

    int sum(double *input, double input_length)
    

    要在 sum 函数中包含遍历输入向量的所有元素的 for 循环,输入:

    for(i=0; i < input_length; i++) {
    ......
    }

在转移动作中使用函数调用

此图在转移动作中使用 C 函数调用。

Chart that contains transition actions with calls to custom code functions fcn1 and fcn2.

如果以下条件成立,则使用 arg1arg2arg3fcn1 进行函数调用:

  • S1 被激活。

  • 发生事件 e

  • 条件 c 为 true。

  • 转移目标 S2 有效。

此外,从 S2S3 的转移中的转移动作显示了嵌套在另一个函数调用中的函数调用示例。

在状态动作中使用函数调用

下图在状态动作中使用函数调用。

Chart that contains state actions with calls to custom code functions fcn1 and fcn2.

当图执行时:

  1. 发生到 S1 的默认转移,S1 被激活。

  2. 执行 entry 动作,它使用指定参量对 fcn1 进行函数调用。

  3. 在仿真时间经过 5 秒后,S1 变为非激活,S2 被激活。

  4. 执行 during 动作,它使用指定参量对 fcn2 进行函数调用。

  5. 在仿真时间经过 10 秒后,S2 变为非激活,S1 再次被激活。

  6. 在仿真结束之前,重复步骤 2 到 5。

按引用传递参量

图动作可以按引用(而不是按值)将参量传递给用户编写的函数。例如,动作可以包含函数调用:

f(&x);

其中 f 是自定义代码 C 函数,它需要指向 x 的指针作为参量。

如果 x 是 Stateflow 层次结构中数据项的名称,则适用以下规则:

  • 不要使用指针传递从 Simulink® 模型输入的数据项。

    如果您需要按引用传递某输入项(例如数组),请将该项分配给一个局部数据项并按引用传递该局部数据项。

  • 如果 x 的数据类型为 boolean,则您必须关闭模型配置参数使用位集来存储状态配置

  • 如果 x 是数组且第一个索引属性为 0,则必须使用 f(&(x[0])); 调用该函数。此语法会将 x 的第一个元素的指针传递给函数。请参阅设置数据属性

  • 如果 x 是数组且第一个索引属性为非零数字,则必须使用 f(&(x[1])) 调用该函数。此语法会将 x 的第一个元素的指针传递给函数。

另请参阅

主题