coder.extrinsic
将一个函数声明为外部函数并在函数中执行MATLAB
语法
描述
coder.extrinsic (
声明函数
)函数
作为一个外在函数。代码生成器并不为外部函数体生成代码,而是使用MATLAB®引擎执行调用。只有当MATLAB引擎在执行过程中可用时,此功能才可用。MATLAB引擎可用的例子包括MEX函数的执行,Simulink®模拟,或代码生成时的函数调用(也称为编译时)。
在独立代码生成过程中,代码生成器试图确定外部函数是否只具有副作用(例如,通过显示一个图),或者它是否影响调用它的函数的输出(例如,通过向输出变量返回一个值)。如果输出没有变化,代码生成器将继续进行代码生成,但将外部函数从生成的代码中排除。否则,代码生成器将产生编译错误。
你不能使用coder.ceval
在您声明为外部的函数上使用coder.extrinsic
.此外,coder.extrinsic
指令在代码生成之外被忽略。
请注意
代码生成器自动处理许多常见的MATLAB可视化函数,例如情节
,disp
,数字
外在。您不必通过使用显式地将它们声明为外部函数coder.extrinsic
.
coder.extrinsic (function1,...functionN)
声明function1
通过functionN
非本征函数。
coder.extrinsic (
允许在调用外部函数之前和之后,在MATLAB执行和生成的代码执行或Simulink模拟之间同步全局数据的同步:
, function1,…functionN)function1
通过functionN
.如果只有少数外部调用使用或修改全局数据,则通过将全局同步模式设置为,在所有外部函数调用之前和之后关闭同步在mex函数的入口和出口
.使用的同步:
选项仅为修改全局数据的外部调用启用同步。
如果你使用MATLAB编码器™生成一个MEX函数的同步:
选项允许在调用外部函数后验证MATLAB和MEX函数之间的常量全局数据的一致性。
看到为全局数据生成代码.
coder.extrinsic (
禁用在调用外部函数之前和之后的MATLAB执行和生成代码执行之间的全局数据同步“同步:掉”
, function1,…functionN)function1
通过functionN
.如果大多数外部调用使用或修改全局数据,但少数调用不使用“同步:掉”
选项关闭不修改全局数据的外部调用的同步。
如果你使用MATLAB编码器生成一个MEX函数“同步:掉”
选项禁止在调用外部函数后验证MATLAB和MEX函数之间的常量全局数据的一致性。
看到为全局数据生成代码.
例子
输入参数
限制
外部函数调用有一些可能影响性能的开销。在外部函数调用中传递的输入数据必须提供给MATLAB,这需要制作数据的副本。如果函数有任何输出数据,则必须将该数据传输回MEX函数环境,这也需要一份副本。
的代码生成器不支持使用
coder.extrinsic
调用位于私有文件夹中的函数。的代码生成器不支持使用
coder.extrinsic
调用局部函数。
提示
扩展功能
版本历史
介绍了R2011a