编码器。MexCodeConfig
配置参数用于生成MEX功能MATLAB代码
描述
一个编码器。MexCodeConfig
对象包含用于codegen
在生成MEX函数时使用。将对象传递给codegen
函数,使用配置
选择。
创建
创建一个编码器。MexCodeConfig
对象,使用coder.config
函数。
一旦你创建了编码器。MexCodeConfig
对象,您可以在命令行以编程方式或使用配置参数对话框以交互方式修改其属性。看到在命令行工作流中交互式地指定配置参数.
属性
CacheDynamicArrayDataPointer
- - - - - -动态阵列优化
真正的
(默认)|假
CodeFormattingTool
- - - - - -格式化工具生成的代码
“汽车”
(默认)|“Clang-format”
|“MathWorks”
生成的代码的代码格式化选项,指定为表中的值之一。
价值 | 描述 |
---|---|
“Clang-format” |
类对生成的代码进行格式化 |
“汽车” |
使用内部启发式来确定生成的代码是否被格式化 来确定所生成的代码是否被格式化 |
“MathWorks” |
使代码生成器恢复到MathWorks格式化工具。 |
CompileTimeRecursionLimit
- - - - - -编译时递归函数特化的最大数量
50(默认)|正整数
编译时递归的函数特化的最大数目,指定为正整数。在MATLAB中不允许递归®代码,设置CompileTimeRecursionLimit
为0。默认的编译时递归限制对于大多数需要这种类型递归的递归函数来说足够大。如果由于编译时递归限制而导致代码生成失败,而您想要编译时递归,请尝试增加限制。或者,更改MATLAB代码,使代码生成器使用运行时递归。看到达到编译时递归限制.
ConstantFoldingTimeout
- - - - - -常量文件夹可执行的最大指令数
40000(默认)|正整数
常量文件夹执行的最大指令数。在某些情况下,代码生成需要特定的指令保持不变。如果常数折叠在这些指令被常数折叠之前停止,代码生成就会失败。在这种情况下,增加的值ConstantFoldingTimeout
.
ConstantInputs
- - - - - -恒输入检查模式
“CheckValues”
(默认)|“IgnoreValues”
|“删除”
常量输入检查模式,指定为本表中的值之一。
价值 | 描述 |
---|---|
“CheckValues” |
此值为默认值。 在调用MEX函数时,它会检查为常量输入参数提供的值是否为代码生成时指定的值。 可以使用相同的参数调用MEX函数和原始MATLAB函数。因此,您可以对两个函数使用相同的测试文件。 检查这些值会降低MEX函数的执行速度。 |
“IgnoreValues” |
在调用MEX函数时,它会忽略为常量输入参数提供的值。它使用在代码生成时指定的值。 您可以使用相同的测试文件,而无需检查常量参数值的开销。 |
“删除” |
代码生成器从MEX函数签名中删除常量输入参数。在调用MEX函数时,不为常量输入参数提供值。 此选项提供向后兼容性。 |
CppGenerateEnumClass
- - - - - -生成c++ 11的MATLAB枚举类
真正的
(默认)|假
是否生成包含枚举类或普通C枚举的c++ 11代码,指定为本表中的值之一。
价值 | 描述 |
---|---|
真正的 |
此值为默认值。 代码生成器在生成的c++ 11代码中为MATLAB枚举生成枚举类。看到枚举的代码生成. |
假 |
代码生成器在生成的c++ 11代码中为MATLAB枚举生成普通C枚举。 |
依赖:
设置
TargetLang
来“c++”
启用此参数。
CppPackagesToNamespaces
- - - - - -为MATLAB包生成c++命名空间
真正的
(默认)|假
是否为MATLAB代码中的包生成c++名称空间,指定为本表中的值之一。
价值 | 描述 |
---|---|
真正的 |
此值为默认值。 代码生成器为MATLAB代码中的包生成c++名称空间。看到将生成的c++代码组织到命名空间中. |
假 |
代码生成器不会为MATLAB代码中的包生成c++名称空间。 |
依赖:
设置
TargetLang
来“c++”
启用此参数。
数据类型:逻辑
CppNamespace
- - - - - -生成的c++代码的命名空间名称
”
(默认)|特征向量
CppNamespaceForMathworksCode
- - - - - -将为MathWorks代码生成的c++代码放在单独的名称空间中
“编码器”
(默认)|特征向量
为MathWorks代码生成的c++代码的命名空间。如果将此属性指定为空字符向量,则代码生成器不会生成这样的名称空间。
依赖:
设置
TargetLang
来“c++”
启用此参数。
数据类型:字符
CppPreserveClasses
- - - - - -为MATLAB类生成c++类
真正的
(默认)|假
是否为MATLAB类生成c++类或C风格结构,指定为本表中的值之一。
价值 | 描述 |
---|---|
真正的 |
此值为默认值。 代码生成器为MATLAB类生成c++类。看到生成MATLAB类的c++类. |
假 |
代码生成器为MATLAB类生成C风格的结构。 |
当使用GPU Coder™时,代码生成器总是禁用此参数。
依赖:
设置
TargetLang
来“c++”
启用此参数。
数据类型:逻辑
CustomHeaderCode
- - - - - -出现在生成的C/ c++头文件顶部的自定义代码
' '(默认)|特征向量
出现在从MATLAB代码生成的每个C/ c++头文件顶部附近的自定义代码,除非rtwtypes.h
而且rtwhalf.h
,指定为字符向量。
CustomInclude
- - - - - -要添加到编译生成代码的包含路径的包含文件夹
' '(默认)|字符串数组|字符向量的单元格数组|特征向量
在编译生成的代码时要添加到Include路径中的Include文件夹。将包含文件夹列表指定为字符串数组、字符向量的单元格数组或字符向量。
多个文件夹名,指定为此表中的值之一。
价值 | 描述 |
---|---|
字符串数组 | 中的字符串数组。 |
字符向量的单元格数组 | 中字符向量的单元格数组 |
特征向量 | 分隔包含文件夹 请注意 在未来的版本中,将不再使用字符向量在代码配置对象中指定多个条目。使用字符向量的字符串数组和单元格数组。有关更多信息,请参见兼容性的考虑. |
CustomInitializer
- - - - - -要包含在生成的初始化函数中的自定义代码
' '(默认)|特征向量
要包含在生成的初始化函数中的自定义代码,指定为字符向量。
CustomLibrary
- - - - - -与生成的代码链接的静态库文件
' '(默认)|字符串数组|字符向量的单元格数组|特征向量
与生成的代码链接的静态库文件,指定为字符串数组、单元格数组的字符向量或字符向量。
多个静态库文件名,指定为本表中的值之一。
价值 | 描述 |
---|---|
字符串数组 | 中的字符串数组。 |
字符向量的单元格数组 | 中字符向量的单元格数组 |
特征向量 | 分隔静态库文件名 请注意 在未来的版本中,将不再使用字符向量在代码配置对象中指定多个条目。使用字符向量的字符串数组和单元格数组。有关更多信息,请参见兼容性的考虑. |
CustomSource
- - - - - -要编译并与生成的代码链接的源文件
' '(默认)|字符串数组|字符向量的单元格数组|特征向量
要编译并与生成的代码链接的源文件,指定为字符串数组、字符向量的单元格数组或字符向量。
构建过程首先在当前文件夹中搜索源文件,然后在您指定的包含文件夹中搜索CustomInclude
.如果具有相同名称的源文件出现在搜索路径上的多个文件夹中,则构建过程可能使用与您指定的文件不同的文件。
假设你指定foo.cpp
作为源文件。如果foo.c
而且foo.cpp
都在搜索路径上,您无法确定构建过程是否使用foo.c
或foo.cpp
.
多个源文件名,指定为本表中的值之一。
价值 | 描述 |
---|---|
字符串数组 | 中的字符串数组。 |
字符向量的单元格数组 | 中字符向量的单元格数组 |
特征向量 | 用a分隔源文件名 请注意 在未来的版本中,将不再使用字符向量在代码配置对象中指定多个条目。使用字符向量的字符串数组和单元格数组。有关更多信息,请参见兼容性的考虑. |
CustomSourceCode
- - - - - -代码显示在生成的.c
或. cpp
文件
' '(默认)|特征向量
指定代码以出现在每个生成的代码的顶部附近.c
或. cpp
文件(除了rtwhalf.c
或rtwhalf.cpp
),在任何功能之外。将code指定为字符向量。
不要指定C静态函数定义。
CustomTerminator
- - - - - -出现在生成的终止函数中的代码
' '(默认)|特征向量
出现在生成的终止函数中的代码,指定为字符向量。
DeepLearningConfig
- - - - - -深度学习代码生成的配置对象
编码器。MklDNNConfig
对象|编码器。CuDNNConfig
对象|编码器。TensorRTConfig
对象
深度学习网络代码生成的配置对象,指定为本表中的对象之一。
对象 | 需要 | 描述 |
---|---|---|
编码器。MklDNNConfig |
|
一个 CFG = code .config(墨西哥人的);cfg。TargetLang =“c++”;cfg。DeepLearningConfig =编码器。DeepLearningConfig (“mkldnn”); |
编码器。CuDNNConfig (GPU编码器) |
|
一个 cfg = code . gpuconfig (“自由”);cfg。TargetLang =“c++”;cfg。DeepLearningConfig =编码器。DeepLearningConfig (“cudnn”); 看到基于cuDNN的深度学习网络代码生成(GPU编码器). |
编码器。TensorRTConfig (GPU编码器) |
|
一个 cfg = code . gpuconfig (“自由”);cfg。TargetLang =“c++”;cfg。DeepLearningConfig =编码器。DeepLearningConfig (“tensorrt”); 看到基于TensorRT的深度学习网络代码生成(GPU编码器). |
请注意
使用ARM进行深度学习时,不支持生成MEX代码®计算库。
依赖:如果DeepLearningConfig
是集,codegen
集TargetLang
来c++
.
DynamicMemoryAllocation
- - - - - -动态内存分配模式
“阈值”
(默认)|“AllVariableSizeArrays”
|“关闭”
动态内存分配模式,指定为该表中的一个值。
价值 | 描述 |
---|---|
“阈值” |
此值为默认值。 代码生成器在堆上为大小(以字节为单位)大于或等于的可变大小数组动态分配内存 |
“AllVariableSizeArrays” |
代码生成器动态地为堆上所有可变大小的数组分配内存。 |
“关闭” |
代码生成器静态地为堆栈上的可变大小数组分配内存。 |
无界可变大小数组需要动态内存分配。
依赖关系:
EnableVariableSizing
启用此参数。设置这个
DynamicMemoryAllocation
来“阈值”
使DynamicMemoryAllocationThreshold
参数。
看到生成可变大小数据的代码.
DynamicMemoryAllocationInterface
- - - - - -在生成的函数接口上动态分配数组
“汽车”
(默认)|“C”
|“c++”
在生成的C/ c++函数的接口上动态分配数组的实现,指定为本表中的值之一。
价值 | 描述 |
---|---|
“汽车” |
这是默认值。如果你设置 |
“C” |
生成的代码使用C样式 |
“c++” |
如果你设置 生成的代码使用 |
当使用GPU Coder时,代码生成器总是使用C风格emxArray
数据结构。
依赖:
EnableVariableSizing
启用此参数。
DynamicMemoryAllocationThreshold
- - - - - -可变大小数组动态内存分配的大小阈值
65536
(默认)|正整数
固定大小和可变大小数组的动态内存分配的大小阈值,指定为正整数。代码生成器对大小(以字节为单位)大于或等于阈值的固定大小和可变大小数组使用动态内存分配。
依赖:
设置
DynamicMemoryAllocation
来“阈值”
启用此参数。
看到生成可变大小数据的代码.
EnableAutoParallelization
- - - - - -自动并行化为
循环
假
(默认)|真正的
自动并行化为
循环,指定为本表中的值之一。
价值 | 描述 |
---|---|
假 |
此值为默认值。 代码生成器不会自动并行化 |
真正的 |
代码生成器自动并行化 |
当使用GPU编码器,代码生成器总是启用自动并行化为
循环。
数据类型:逻辑
EnableAutoParallelizationReporting
- - - - - -的自动并行化报告为
循环
真正的
(默认)|假
的自动并行化报告为
循环,指定为本表中的值之一。
价值 | 描述 |
---|---|
真正的 |
此值为默认值。 如果你设置 |
假 |
的自动并行化代码生成器不会生成代码生成报告为 循环。 |
EchoExpressions
- - - - - -表达呼应
真正的
(默认)|假
表达式回显,指定为本表中的值之一。
价值 | 描述 |
---|---|
真正的 |
此值为默认值。 MEX函数显示不以分号结尾的语句的输出。 |
假 |
MEX函数不显示以分号结尾的语句的输出。 |
此属性不适用于常见的可视化函数,例如disp
,情节
,或数字
当它们作为外部函数被调用时。的值,无论是否存在分号或值,MEX函数都显示这些函数的输出EchoExpressions
.
EnableAutoExtrinsicCalls
- - - - - -自动外部函数调用
真正的
(默认)|假
自动外部函数调用,指定为本表中的值之一。
价值 | 描述 |
---|---|
真正的 |
此值为默认值。 代码生成器将一些常见的可视化函数视为外部函数。您不必将这些函数声明为外部函数 |
假 |
代码生成器不会将常见的可视化函数视为外部函数,除非您将它们声明为外部函数coder.extrinsic . |
一些常见的可视化函数是情节
,disp
,数字
.看到使用MATLAB引擎在生成的代码中执行函数调用.
EnableDebugging
- - - - - -C编译器调试模式
假
(默认)|真正的
C编译器调试模式,指定为本表中的值之一。
价值 | 描述 |
---|---|
假 |
此值为默认值。 代码生成器不启用C编译器调试模式。 |
真正的 |
代码生成器启用C编译器调试模式。当启用调试模式时,C编译器不会优化代码。编译速度更快,但执行速度更慢。 |
EnableImplicitExpansion
- - - - - -生成代码中的隐式扩展功能
真正的
(默认)|假
生成的代码中的隐式扩展功能,指定为本表中列出的值之一。
价值 | 描述 |
---|---|
真正的 |
此值为默认值。 代码生成器支持在生成的代码中进行隐式展开。代码生成器在生成的代码中包含修改,以应用隐式展开。看到基本操作的兼容数组大小. |
假 |
生成的代码不遵循隐式展开规则。 |
数据类型:逻辑
EnableJIT
- - - - - -即时(JIT)编译模式
假
(默认)|真正的
即时(JIT)编译模式,指定为该表中的值之一。
价值 | 描述 |
---|---|
假 |
此值为默认值。 代码生成器通过生成和编译C/ c++代码来创建C/ c++ MEX函数。 |
真正的 |
代码生成器使用即时(JIT)编译技术生成MEX函数。代码生成器创建一个JIT MEX函数,其中包含MATLAB代码的抽象表示。当您运行JIT MEX函数时,MATLAB在内存中生成可执行代码。 |
为了加快生成MEX函数的速度,请设置EnableJIT
来真正的
.
JIT编译与某些代码生成特性和选项不兼容,例如自定义代码或OpenMP库的使用。如果您指定了JIT编译,而代码生成器无法使用它,它将生成一个带有警告的C/ c++ MEX函数。如果EnableJIT
而且EnableOpenMP
是真正的
,并且您的代码使用parfor
时,代码生成器使用JIT编译并处理parfor
循环,为
循环。
EnableMemcpy
- - - - - -memcpy
优化
真正的
(默认)|假
memcpy
优化,指定为本表中的值之一。
价值 | 描述 |
---|---|
真正的 |
此值为默认值。 如果可能,代码生成器使用 |
假 |
代码生成器不使用 |
当使用GPU编码器时,代码生成器总是禁用的Memcpy
优化。
EnableMexProfiling
- - - - - -剖析仪器
假
(默认)|真正的
启用生成的MEX函数的分析,该函数指定为本表中的值之一。
价值 | 描述 |
---|---|
假 |
此值为默认值。 代码生成器在生成的MEX函数中不包括用于分析的工具。 |
真正的 |
代码生成器在生成的MEX函数中包含用于分析的工具。然后,您可以使用MATLAB Profiler来分析MEX。看到利用MATLAB Profiler分析MEX函数. |
EnableOpenMP
- - - - - -并行化的parfor
循环
真正的
(默认)|假
并行化的parfor
-loops,指定为该表中的一个值。
价值 | 描述 |
---|---|
真正的 |
此值为默认值。 如果可能的话,代码生成器使用OpenMP库生成并行运行的循环迭代。 |
假 |
代码生成器处理 |
看到parfor
.
OpenMP库的使用与即时(JIT)编译不兼容。如果EnableJIT
而且EnableOpenMP
是真正的
,代码生成器使用JIT编译和处理parfor
循环,为
循环。
当使用GPU编码器,代码生成器总是处理parfor
循环,为
循环。
EnableRuntimeRecursion
- - - - - -运行时递归支持
真正的
(默认)|假
运行时递归支持,指定为本表中的值之一。
价值 | 描述 |
---|---|
真正的 |
此值为默认值。 在生成的代码中允许使用递归函数。 |
假 |
在生成的代码中不允许使用递归函数。 |
一些编码标准,如MISRA®,不允许递归。增加生成与MISRA C兼容的代码的可能性®,设置EnableRuntimeRecursion
来假
.
如果你的MATLAB代码需要运行时递归和EnableRuntimeRecursion
是假
,代码生成失败。
看到递归函数的代码生成.
EnableVariableSizing
- - - - - -可变大小的数组支持
真正的
(默认)|假
可变大小的数组支持,指定为本表中的值之一。
价值 | 描述 |
---|---|
真正的 |
此值为默认值。 代码生成允许使用可变大小的数组。 |
假 |
代码生成不允许使用可变大小的数组。 |
依赖:
使
动态内存分配
.
看到可变大小数组的代码生成.
ExtrinsicCalls
- - - - - -外部函数调用支持
真正的
(默认)|假
外部函数调用支持,指定为本表中的值之一。
价值 | 描述 |
---|---|
真正的 |
此值为默认值。 对于外部函数,代码生成器生成对MATLAB函数的调用。代码生成器不生成函数的内部代码。 |
假 |
代码生成器忽略外部函数。它不生成调用MATLAB函数的代码。如果外部函数影响MATLAB函数的输出,代码生成器将发出编译错误。 如果你设置 |
的价值ExtrinsicCalls
影响MEX函数如何为rand生成随机数,
兰迪
,randn
.如果ExtrinsicCalls
是真正的
, MEX函数使用MATLAB全局随机数流生成随机数。否则,MEX函数使用一个自包含的随机数生成器。
FilePartitionMethod
- - - - - -文件分区模式
“MapMFileToCFile”
(默认)|“SingleFile”
文件分区模式指定为此表中的值之一。
价值 | 描述 |
---|---|
“MapMFileToCFile” |
此值为默认值。 代码生成器为每个MATLAB语言文件生成单独的C/ c++文件。 |
“SingleFile” |
代码生成器为映射到MATLAB入口点函数的C/ c++函数生成单个文件。代码生成器为实用函数生成单独的C/ c++文件。 |
GenCodeOnly
- - - - - -只生成源代码
假
(默认)|真正的
只生成源代码,指定为此表中的值之一。
价值 | 描述 |
---|---|
假 |
此值为默认值。 代码生成器生成C/ c++源代码并构建目标代码。 |
真正的 |
代码生成器生成C/ c++源代码,但不调用make命令或构建目标代码。当您在修改MATLAB代码和生成C/ c++代码之间迭代时,只生成代码可以节省时间。 |
GenerateComments
- - - - - -生成代码中的注释
真正的
(默认)|假
生成的代码中的注释,指定为本表中的值之一。
价值 | 描述 |
---|---|
真正的 |
此值为默认值。 代码生成器在生成的代码中放置注释。 |
假 |
代码生成器不会在生成的代码中放置注释。 |
GenerateReport
- - - - - -代码生成报告
假
(默认)|真正的
代码生成报告,指定为本表中的值之一。
价值 | 描述 |
---|---|
假 |
此值为默认值。 代码生成器仅在发生错误或警告消息或设置 |
真正的 |
代码生成器生成一个代码生成报告。 |
GlobalDataSyncMethod
- - - - - -全局数据同步模式
“SyncAlways”
(默认)|“SyncAtEntryAndExits”
|“NoSync”
全局数据同步模式,指定为本表中的值之一。
价值 | 全局数据描述 | 常量全局数据的描述 |
---|---|---|
|
此值为默认值。 在MEX函数入口和出口以及外部调用处同步全局数据,以实现MATLAB和生成的MEX函数之间的最大一致性。为最大化性能,如果外部调用不更改全局数据,请将此选项与 |
在MEX函数入口处和外部调用后验证常量全局数据的一致性。如果MATLAB全局工作空间中的全局数据值与MEX函数中的编译时常量全局值不一致,则MEX函数将以错误结束。使用 |
|
仅在MEX函数入口和出口同步全局数据。为最大化性能,如果只有少数外部调用更改全局数据,请使用此选项和 |
仅在MEX函数入口处验证常量全局数据。如果MATLAB全局工作空间中的全局数据值与MEX函数中的编译时常量全局值不一致,则MEX函数将以错误结束。使用 |
|
禁用同步。在禁用同步之前,请验证MEX函数不与MATLAB全局数据交互。否则,MATLAB和MEX函数之间可能会出现不一致。 |
禁用一致性检查。 |
看到为全局数据生成代码.
HighlightPotentialRowMajorIssues
- - - - - -潜在的行主布局问题
真正的
(默认)|假
显示潜在的行主布局效率问题,指定为本表中的值之一。
价值 | 描述 |
---|---|
真正的 |
代码生成报告显示了由于行主布局而导致的潜在效率问题。(此值为默认值。) |
假 |
代码生成报告不显示与数组布局相关的问题。 |
看到行-主数组布局代码设计.
InitFltsAndDblsToZero
- - - - - -memset的浮点数和双零的分配
真正的
(默认)|假
浮点数和双零的赋值memset
,指定为本表中的值之一。
价值 | 描述 |
---|---|
真正的 |
此值为默认值。 如果可能,代码生成器使用 |
假 |
代码生成器不使用 |
InlineBetweenMathWorksFunctions
- - - - - -MathWorks函数之间的控件内联
“速度”
(默认)|“总是”
|“可读性”
|“永远”
在MathWorks调用另一个MathWorks函数(指定为本表中的值之一)的所有调用站点上的内联行为。
价值 | 描述 |
---|---|
“速度” |
此值为默认值。 使用内部启发式来确定是否在调用站点执行内联。这种设置通常会产生高度优化的代码。 |
“总是” |
总是在调用站点执行内联。 |
“可读性” |
几乎从不内联函数调用,除非调用非常小的函数。尽可能在不牺牲太多速度的情况下保持代码的模块化。结果是高可读性的代码。 |
“永远” |
永远不要内联函数调用。结果是最大的可读性。这种设置可能会显著降低生成代码的性能。 |
即使你选择了“总是”
或者是“永远”
选项的设置,在某些情况下,代码生成器可能不会严格遵循该指令。例如,如果存在冲突,则coder.inline(总是)
或coder.inline(“不”)
置于函数体中的指令将覆盖此选项。有关更多信息,请参见不同内联控件之间的交互.
InlineBetweenUserAndMathWorksFunctions
- - - - - -用户编写的函数和MathWorks函数之间的控件内联
“速度”
(默认)|“总是”
|“可读性”
|“永远”
在您编写的函数调用MathWorks函数或MathWorks函数调用您编写的函数的所有调用站点上的内联行为。指定为本表中的值之一。
价值 | 描述 |
---|---|
“速度” |
此值为默认值。 使用内部启发式来确定是否在调用站点执行内联。这种设置通常会产生高度优化的代码。 |
“总是” |
总是在调用站点执行内联。 |
“可读性” |
几乎从不内联函数调用,除非调用非常小的函数。尽可能在不牺牲太多速度的情况下保持代码的模块化。结果是高可读性的代码。 |
“永远” |
永远不要内联函数调用。结果是最大的可读性。这种设置可能会显著降低生成代码的性能。 |
即使你选择了“总是”
或者是“永远”
选项的设置,在某些情况下,代码生成器可能不会严格遵循该指令。例如,如果存在冲突,则coder.inline(总是)
或coder.inline(“不”)
置于函数体中的指令将覆盖此选项。有关更多信息,请参见不同内联控件之间的交互.
InlineBetweenUserFunctions
- - - - - -控制用户编写的函数之间的内联
“速度”
(默认)|“总是”
|“可读性”
|“永远”
在您编写的函数调用另一个您编写的函数(指定为本表中的值之一)的所有调用站点上的内联行为。
价值 | 描述 |
---|---|
“速度” |
此值为默认值。 使用内部启发式来确定是否在调用站点执行内联。这种设置通常会产生高度优化的代码。 |
“总是” |
总是在调用站点执行内联。 |
“可读性” |
几乎从不内联函数调用,除非调用非常小的函数。尽可能在不牺牲太多速度的情况下保持代码的模块化。结果是高可读性的代码。 |
“永远” |
永远不要内联函数调用。结果是最大的可读性。这种设置可能会显著降低生成代码的性能。 |
即使你选择了“总是”
或者是“永远”
选项的设置,在某些情况下,代码生成器可能不会严格遵循该指令。例如,如果存在冲突,则coder.inline(总是)
或coder.inline(“不”)
置于函数体中的指令将覆盖此选项。有关更多信息,请参见不同内联控件之间的交互.
IntegrityChecks
- - - - - -内存完整性检查
真正的
(默认)|假
内存完整性检查,指定为本表中的值之一。
价值 | 描述 |
---|---|
真正的 |
此值为默认值。 生成的代码检测内存完整性违规,并使用诊断消息停止执行。 |
假 |
生成的代码不会检测内存完整性违规。 设置 |
看到控制运行时检查.
LaunchReport
- - - - - -自动打开代码生成报告
假
(默认)|真正的
自动打开生成报告的代码,指定为本表中的值之一。
价值 | 描述 |
---|---|
假 |
此值为默认值。 如果发生错误或警告,或者如果 |
真正的 |
代码生成器生成并打开代码生成报告。 |
MATLABSourceComments
- - - - - -在生成的代码中包含MATLAB源代码作为注释
假
(默认)|真正的
在生成的代码中包含MATLAB源代码作为注释,指定为本表中的值之一。
价值 | 描述 |
---|---|
假 |
此值为默认值。 代码生成器不会在生成的代码中插入MATLAB源代码作为注释。代码生成器在函数横幅中不包含MATLAB函数签名。 |
真正的 |
代码生成器在生成的代码中插入MATLAB源代码作为注释。可追溯性标记立即位于源代码的每一行之前。可追溯性标签帮助您定位相应的MATLAB源代码。看到跟踪生成的C/ c++代码到MATLAB源代码. 代码生成器还在函数横幅中包含MATLAB函数签名。 |
依赖:
GenerateComments
启用此参数。
的名字
- - - - - -对象名称
“MexCodeConfig”
(默认)|特征向量
对象名称,指定为字符向量。
NumberOfCpuThreads
- - - - - -并行for-loops运行的最大CPU线程数
0(默认)|正整数
并行运行的最大CPU线程数为
-循环在生成的C/ c++代码中,指定为正整数。
PostCodeGenCommand
- - - - - -命令自定义生成处理
”
(默认)|特征向量
命令用于自定义生成处理后的MEX功能生成codegen
,指定为字符向量。
看到构建过程定制.
PreserveArrayDimensions
- - - - - -n维索引
假
(默认)|真正的
PreserveVariableNames
- - - - - -要保存在生成代码中的变量名
“没有”
(默认)|“用户名”
|“所有”
要保存在生成的代码中的变量名,指定为本表中的值之一。
价值 | 描述 |
---|---|
“没有” |
此值为默认值。 代码生成器不必保留任何变量名。它可以重用任何满足变量重用要求的变量。 如果您的代码使用大型结构或数组,设置 |
“用户名” |
代码生成器保留与MATLAB代码中定义的变量对应的名称。它不会将您的变量名替换为另一个名称,也不会将您的名称用于另一个变量。为了提高可读性,设置 设置 |
“所有” |
保留所有变量名。该参数值禁止变量重用。只能将其用于测试或调试,而不能用于生产代码。 |
看到在生成的代码中保留变量名.
ReportInfoVarName
- - - - - -包含代码生成报告信息的变量的名称
”
(默认)|特征向量
将有关代码生成的信息导出到其中的变量的名称,指定为字符向量。代码生成器在基本MATLAB工作区中创建此变量。此变量包含有关代码生成设置、输入文件、生成文件和代码生成消息的信息。
ReportPotentialDifferences
- - - - - -潜在差异报告
真正的
(默认)|假
潜在差异报告,指定为本表中的值之一:
价值 | 描述 |
---|---|
真正的 |
代码生成器报告生成的代码和MATLAB代码之间的潜在行为差异。代码生成报告的选项卡上列出了潜在的差异。电位差是在运行时仅在某些条件下发生的差。 |
假 |
代码生成器不会报告潜在的差异。 |
看到潜在差异报告.
ReservedNameArray
- - - - - -代码生成器不能用于函数或变量的名称
”
(默认)|字符串数组|字符向量的单元格数组|特征向量
代码生成器不能用于函数或变量的名称列表,指定为字符串数组、字符向量的单元格数组或字符向量。
多个保留名称,指定为此表中的一个值。
价值 | 描述 |
---|---|
字符串数组 | 中的字符串数组。 |
字符向量的单元格数组 | 中字符向量的单元格数组 |
特征向量 | 中以分号分隔的保留名称列表 请注意 在未来的版本中,将不再使用字符向量在代码配置对象中指定多个条目。使用字符向量的字符串数组和单元格数组。有关更多信息,请参见兼容性的考虑. |
ResponsivenessChecks
- - - - - -响应性检查
真正的
(默认)|假
响应性检查,指定为本表中的值之一。
价值 | 描述 |
---|---|
真正的 |
此值为默认值。 你可以使用Ctrl + C停止执行生成的MEX函数。 |
假 |
要结束长时间运行的MEX函数,可能必须终止MATLAB。 |
当使用GPU编码器时,代码生成器总是禁用此参数。
看到控制运行时检查.
RowMajor
- - - - - -行主数组布局
假
(默认)|真正的
SaturateOnIntegerOverflow
- - - - - -整数溢出支持
真正的
(默认)|假
整数溢出支持,指定为本表中的值之一。
价值 | 描述 |
---|---|
真正的 |
此值为默认值。 代码生成器生成处理整数溢出的代码。溢出饱和到数据类型可以表示的最小值或最大值。 |
假 |
代码生成器不会生成处理整数溢出的代码。不要设置 |
此参数仅适用于MATLAB内置整数类型。它不适用于双精度、单精度或定点数据类型。
StackUsageMax
- - - - - -每个应用程序的最大堆栈使用量
200000
(默认)|正整数
每个应用程序的最大堆栈使用量(以字节为单位),指定为正整数。设置一个低于可用堆栈大小的限制。否则,可能会发生运行时堆栈溢出。C编译器检测并报告堆栈溢出。
看到控制堆叠空间使用.
TargetLang
- - - - - -在生成的代码中使用的语言
“C”
(默认)|“c++”
在生成的代码中使用的语言,指定为“C”
或“c++”
.如果指定c++,代码生成器将C代码包装到.cpp文件中,以便您可以使用c++编译器并与外部c++应用程序进行接口。它不生成c++类。
当使用GPU编码器时,代码生成集TargetLang
来c++
.
依赖:如果DeepLearningConfig
是集,codegen
集TargetLang
来c++
.
冗长
- - - - - -代码生成进度显示
“信息”
(默认)|“沉默”
|“详细”
是否在MATLAB命令行中显示代码生成进度的状态,指定为本表中的值之一。
价值 | 描述 |
---|---|
“沉默” |
如果代码生成成功而没有警告,则所有消息都将被抑制,包括在生成报告时。 显示警告和错误信息。 |
“信息” |
此值为默认值。 相比之下
|
“详细” |
中显示的消息之外 |
例子
指定生成MEX功能的配置参数
编写一个可以生成代码的MATLAB函数。本例使用了该函数myadd
返回输入的和。
函数C = myadd(a,b) C = a + b;结束
创建用于生成MEX功能的配置对象。
CFG = code .config(墨西哥人的);
更改不希望使用默认值的属性的值。例如,启用即时(JIT)编译。
cfg。EnableJIT = true;
使用以下命令生成代码codegen
.将配置对象传递给codegen
通过使用配置
选择。指定输入参数为标量双精度。
codegenmyadd配置cfgarg游戏{1}报告
选择功能
如果使用缺省配置参数值生成MEX函数,则不需要创建配置对象,可以调用codegen
属性,而不指定配置对象配置:墨西哥人
选择。
版本历史
在R2011a中引入R2021a:使用字符向量在代码配置对象中指定多个条目的能力将被移除
在未来的版本中,通过使用字符向量或具有分隔符的字符串标量在代码配置对象中指定多个文件名、路径或保留名称的操作将被删除。请使用字符串数组和字符向量的单元格数组。例如,要包含多个文件夹名称,可以在中使用字符串数组CustomInclude
作为cfg。CustomInclude = ["C:\项目","C:\自定义文件"];
或由字符向量组成的单元格数组cfg。CustomInclude = {'C:\项目','C:\自定义文件'};
包含编译生成代码的路径。
MATLAB命令
你点击了一个对应于这个MATLAB命令的链接:
在MATLAB命令窗口中输入该命令来运行该命令。Web浏览器不支持MATLAB命令。
您也可以从以下列表中选择一个网站:
如何获得最佳的网站性能
选择中国站点(中文或英文)以获得最佳站点性能。其他MathWorks国家站点没有针对您所在位置的访问进行优化。