主要内容

ClassificationLinearCoderConfigurer

编码器配置线性二进制高维数据的分类

自从R2019b

描述

一个ClassificationLinearCoderConfigurer的对象是一个编码器配置线性分类模型(ClassificationLinear)用于二进制高维数据的分类。

一个编码器配置提供了方便的功能配置代码生成选项,生成C / c++代码,生成的代码和更新模型参数。

  • 配置代码生成选项并指定线性模型参数的编码属性使用对象属性。

  • 生成的C / c++代码预测更新通过使用函数的线性分类模型generateCode。需要生成C / c++代码MATLAB®编码器™

  • 更新模型参数生成的C / c++代码,而不必重新生成代码。这个特性可以减少所需的努力再生,重新部署,reverify C / c++代码当你训练线性模型与新数据或设置。在更新模型参数,使用validatedUpdateInputs验证和提取模型参数更新。

这个流程图显示了代码生成使用编码器配置工作流。

两个代码生成工作流:第一个模型训练后,第二次再培训后相同的模型。第一个工作流程,步骤1:创建一个编码器配置。第二步:生成代码。第三步:验证生成的代码。第二个工作流,步骤1:检查是否更新是有效的。如果是的,去步骤2;如果没有,先去的第一步工作流程。步骤2:在生成的代码更新模型参数。

的代码生成使用笔记和一个线性分类模型的局限性,看到的代码生成部分ClassificationLinear,预测,更新

创建

训练后利用线性分类模型fitclinear为模型,创建一个编码器配置使用learnerCoderConfigurer。使用一个编码器的属性配置指定的编码属性预测更新参数。然后,用generateCode生成C / c++代码根据指定的编码属性。

属性

全部展开

预测参数

在这一节中列出的属性指定的编码属性预测函数参数的生成的代码。

编码器的属性预测数据传递给C / c++代码生成预测函数的线性分类模型,指定为一个LearnerCoderInput对象。

当您创建一个编码器配置使用learnerCoderConfigurer函数的输入参数X确定的默认值LearnerCoderInput编码器属性:

  • SizeVector——默认值是数组大小的输入X

    • 如果价值的属性ObservationsIn财产ClassificationLinearCoderConfigurer“行”,那么这SizeVector值是[n p],在那里n对应于观察和的数量p对应的数量预测。

    • 如果价值的属性ObservationsIn财产ClassificationLinearCoderConfigurer“列”,那么这SizeVector值是[p n]

    切换的元素SizeVector(例如,改变[n p][p n]),修改价值的属性ObservationsIn财产ClassificationLinearCoderConfigurer相应的行动。您不能修改SizeVector直接价值。

  • VariableDimensions——默认值是[0 0],这表明中指定数组大小是固定的SizeVector

    你可以设置这个值[1 0]如果SizeVector值是[n p][0 1]如果它是[p n]数组,这表明有适应行和固定大小列。例如,[1 0]指定的第一个值SizeVector(n)是上界的行数,第二个值SizeVector(p)的列数。

  • 数据类型这个值是。默认数据类型取决于输入的数据类型X

  • 可调谐性——这个值必须真正的,这意味着预测在生成的C / c++代码总是包括预测数据作为输入。

您可以修改使用点符号的编码属性。例如,生成C / c++代码接受预测数据与100年的观察(行)三个预测变量(列),指定这些编码器的属性X编码器的配置配置:

configurer.X。SizeVector= [100 3]; configurer.X.DataType =“双”;configurer.X.VariableDimensions= [0 0];
[0 0]表明第一和第二维度X(数量的观察和数量的预测变量,分别)具有固定的大小。

允许生成的C / c++代码接受预测数据与100观察,指定这些编码器的属性X:

configurer.X。SizeVector= [100 3]; configurer.X.DataType =“双”;configurer.X.VariableDimensions= [1 0];
[1 0]表明,第一个维度X(观察)有一个变量的大小和第二维度X(数量的预测变量)具有固定的大小。100年指定数量的观察,在这个例子中,成为了最大允许的观察生成的C / c++代码。允许任意数量的观察,指定绑定

编码器的属性预测数据观察维度(“ObservationsIn”名称-值对的观点预测),指定为一个EnumeratedInput对象。

当您创建一个编码器配置使用learnerCoderConfigurer函数,“ObservationsIn”名称-值对参数确定的默认值EnumeratedInput编码器属性:

  • 价值——默认值是预测数据观察维你使用创建编码器配置时,指定为“行”“列”。如果你不指定“ObservationsIn”在创建编码器配置,默认值是“行”

  • SelectedOption——这个值总是“内置”。这个属性是只读的。

  • BuiltInOptions——单元阵列“行”“列”。这个属性是只读的。

  • IsConstant——这个值必须真正的

  • 可调谐性- - - - - -默认值是如果您指定“ObservationsIn”、“行”在创建编码器配置真正的如果您指定“ObservationsIn”、“列”。如果你设置可调谐性,软件集价值“行”。如果你指定其他属性值可调谐性,软件集可调谐性真正的

的输出参数返回生成的C / c++代码预测函数的线性分类模型,指定为1或2。

的输出参数预测标签(预测类标签)分数(分类的分数),秩序。预测在生成的C / c++代码返回第一个n输出的预测函数,nNumOutputs价值。

在创建了编码器配置配置,您可以指定输出通过使用点符号的数量。

配置。NumOutputs= 2;

NumOutputs属性是相当于“-nargout”编译器选项的codegen(MATLAB编码器)。这个选项指定的输出参数的入口点函数,代码生成。的目标函数generateCode生成两个入口点函数predict.mupdate.m预测更新提供的奖学金函数的线性分类模型,生成C / c++代码的两个入口点函数。指定的值NumOutputs属性对应的入口点函数的输出参数predict.m

数据类型:

更新参数

在这一节中列出的属性指定的编码属性更新函数参数的生成的代码。的更新函数接受一个训练模型和新模型参数作为输入参数,并返回一个更新版本的模型,包含了新的参数。使更新参数在生成的代码中,您需要指定在生成代码的编码属性参数。使用一个LearnerCoderInput对象指定每个参数的编码属性。默认的属性值是基于模型参数的输入参数MdllearnerCoderConfigurer

编码器的属性线性预测系数(β一个线性分类模型),指定为一个LearnerCoderInput对象。

默认的属性值LearnerCoderInput对象是基于输入参数MdllearnerCoderConfigurer:

  • SizeVector——这个值必须(1页),在那里p预测的数量吗Mdl

  • VariableDimensions——这个值必须[0 0],这表明中指定数组大小是固定的SizeVector

  • 数据类型这个值是“单一”“双”。默认数据类型是一致的数据类型使用训练数据训练Mdl

  • 可调谐性——这个值必须真正的

偏见的编码器属性词(偏见一个线性分类模型),指定为一个LearnerCoderInput对象。

默认的属性值LearnerCoderInput对象是基于输入参数MdllearnerCoderConfigurer:

  • SizeVector——这个值必须[1]

  • VariableDimensions——这个值必须[0 0],这表明中指定数组大小是固定的SizeVector

  • 数据类型这个值是“单一”“双”。默认数据类型是一致的数据类型使用训练数据训练Mdl

  • 可调谐性——这个值必须真正的

编码器误分类代价的属性(成本一个线性分类模型),指定为一个LearnerCoderInput对象。

默认的属性值LearnerCoderInput对象是基于输入参数MdllearnerCoderConfigurer:

  • SizeVector——这个值必须(2 - 2)

  • VariableDimensions——这个值必须[0 0],这表明中指定数组大小是固定的SizeVector

  • 数据类型这个值是“单一”“双”。默认数据类型是一致的数据类型使用训练数据训练Mdl

  • 可调谐性——默认值是真正的

编码器的属性先验概率(之前一个线性分类模型),指定为一个LearnerCoderInput对象。

默认的属性值LearnerCoderInput对象是基于输入参数MdllearnerCoderConfigurer:

  • SizeVector——这个值必须(1 2)

  • VariableDimensions——这个值必须[0 0],这表明中指定数组大小是固定的SizeVector

  • 数据类型这个值是“单一”“双”。默认数据类型是一致的数据类型使用训练数据训练Mdl

  • 可调谐性——默认值是真正的

其他配置选项

文件名生成的C / c++代码,指定为一个特征向量。

的目标函数generateCodeClassificationLinearCoderConfigurer生成C / c++代码使用这个文件名称。

文件名称不能包含空格,因为他们可能会导致在某些操作系统配置代码生成失败。此外,名称必须是一个有效的MATLAB函数名。

在创建了编码器配置配置,您可以指定文件名使用点符号。

配置。OutputFileName =“myModel”;

数据类型:字符

冗长的水平,指定为真正的(逻辑1)或(逻辑0)冗长级别控制通知消息的显示在命令行。

价值 描述
真正的(逻辑1) 软件显示通知消息当你更改编码器的属性参数导致其他相关参数的变化。
(逻辑0) 软件不显示通知消息。

使更新机器学习模型参数在生成的代码中,您需要配置在生成代码的编码属性参数。参数的编码属性相互依赖,所以软件商店依赖配置约束。如果你修改一个参数的编码属性使用编码器配置,和修改需要对其他相关参数,以满足后续更改配置约束,那么软件更改的编码属性相关的参数。冗长的水平决定是否为这些后续更改软件显示通知消息。

在创建了编码器配置配置,您可以修改使用点符号的冗长的水平。

配置。详细的= false;

数据类型:逻辑

代码生成定制的选项

使用自定义代码生成工作流generateFiles函数和下面的三个属性codegen(MATLAB编码器),而不是使用generateCode函数。

生成两个入口点函数文件后(predict.mupdate.m)通过使用generateFiles功能,您可以修改这些文件根据你的代码生成工作流。例如,您可以修改predict.m文件包括数据预处理,或者您可以将这些入口点函数添加到另一个代码生成项目。然后,您可以通过使用生成C / c++代码codegen(MATLAB编码器)函数和codegen参数适用于修改后的入口点函数或代码生成项目。使用在这一节中描述的三个属性作为起点设置codegen参数。

这个属性是只读的。

codegen(MATLAB编码器)参数,指定为一个单元阵列。

这个属性使您能够定制代码生成工作流。使用generateCode函数如果你不需要自定义工作流。

而不是使用generateCode编码器的配置配置,您可以生成C / c++代码如下:

generateFiles cgArgs = configurer.CodeGenerationArguments(配置);codegen (cgArgs {}):
如果你定制代码生成工作流、修改cgArgs因此之前调用codegen

如果你修改的其他属性配置,软件更新CodeGenerationArguments相应的属性。

数据类型:细胞

这个属性是只读的。

可调的入口点函数的输入参数列表predict.m对于代码生成,指定为一个单元阵列。细胞数组包含另一个单元阵列,包括coder.PrimitiveType(MATLAB编码器)对象和coder.Constant(MATLAB编码器)对象。

如果你修改的编码属性预测参数相应地,那么软件更新对应的对象。如果你指定可调谐性属性是,那么软件删除对应的对象的PredictInputs列表。

单元阵列的PredictInputs相当于configurer.CodeGenerationArguments {6}编码器的配置配置

数据类型:细胞

这个属性是只读的。

列表的入口点函数的可调输入参数update.m对于代码生成,包括指定的单元阵列结构coder.PrimitiveType(MATLAB编码器)对象。每一个coder.PrimitiveType对象包括编码器属性可调机器学习模型的参数。

如果你修改模型参数的编码属性使用编码器配置属性(更新参数属性),那么相应的软件更新coder.PrimitiveType相应的对象。如果你指定可调谐性机器学习模型参数的属性,然后删除相应的软件coder.PrimitiveType对象的UpdateInputs列表。

的结构UpdateInputs相当于configurer.CodeGenerationArguments {3}编码器的配置配置

数据类型:细胞

对象的功能

generateCode 生成C / c++代码使用编码器配置
generateFiles 生成MATLAB使用编码器配置文件代码生成
validatedUpdateInputs 验证和提取机器学习模型参数更新

例子

全部折叠

火车一个机器学习模型,然后生成代码预测更新功能模型的使用编码器配置。

加载电离层数据集和训练一个二进制线性分类模型。通过转置矩阵预测指标Xnewfitclinear,并使用“ObservationsIn”名称-值对参数指定的列Xnew对应于观测。

负载电离层Xnew = X ';Mdl = fitclinear (Xnew Y“ObservationsIn”,“列”);

Mdl是一个ClassificationLinear对象。

创建一个编码器的配置ClassificationLinear模型通过使用learnerCoderConfigurer。指定的预测数据Xnew,并使用“ObservationsIn”名称-值对参数指定的观察维度Xnew。的learnerCoderConfigurer函数使用这些输入参数来配置相应的编码属性的输入参数预测

配置= learnerCoderConfigurer (Mdl Xnew,“ObservationsIn”,“列”)
配置= ClassificationLinearCoderConfigurer属性:更新输入:β:[1 x1 LearnerCoderInput]偏见:之前[1 x1 LearnerCoderInput]: [1 x1 LearnerCoderInput]成本:[1 x1 LearnerCoderInput]预测输入:X: [1 x1 LearnerCoderInput] ObservationsIn: [1 x1 EnumeratedInput]代码生成参数:NumOutputs: 1 OutputFileName:“ClassificationLinearModel”属性,方法

配置是一个ClassificationLinearCoderConfigurer对象,该对象是一个编码器的配置ClassificationLinear对象。

生成C / c++代码,您必须访问一个C / c++编译器配置正确。MATLAB编码器定位和使用支持,安装编译器。万博1manbetx您可以使用墨西哥人设置查看和更改默认编译器。更多细节,请参阅改变默认的编译器

生成的代码预测更新函数的线性分类模型(Mdl)。

generateCode(配置)
generateCode输出文件夹中创建这些文件:初始化。米”、“预测。米”、“更新。米”、“ClassificationLinearModel。垫的代码生成成功。

generateCode函数完成这些操作:

  • 生成所需的MATLAB文件生成代码,包括两个入口点函数predict.mupdate.m预测更新的功能Mdl,分别。

  • 创建一个墨西哥人函数命名ClassificationLinearModel两个入口点函数。

  • 创建中的墨西哥人功能的代码codegen \墨西哥人\ ClassificationLinearModel文件夹中。

  • 墨西哥人功能复制到当前文件夹。

显示的内容predict.m,update.m,initialize.m文件使用类型函数。

类型predict.m
变长度输入宗量函数varargout =预测(X) % # codegen %自动生成通过MATLAB, 03 - mar - 2023 10:51:09 [varargout {1: nargout}] =初始化(“预测”,X,变长度输入宗量{:});结束
类型update.m
函数更新(变长度输入宗量)% # codegen %自动生成通过MATLAB, 03 - mar - 2023 10:51:09初始化(“更新”,变长度输入宗量{:});结束
类型initialize.m
函数[varargout] =初始化(指挥、变长度输入宗量)% # codegen %自动生成通过MATLAB, 03 - mar - 2023 10:51:09 coder.inline(“总是”)持久模型如果isempty(模型)模型= loadLearnerForCoder (“ClassificationLinearModel.mat”);终端开关(命令)案例'更新' %更新结构体字段:β之前%偏见% % =更新成本模型(模型、变长度输入宗量{:});例“预测”%预测输入:X, ObservationsIn X =变长度输入宗量{1};如果输入参数个数= = 2 (varargout {1: nargout}] =预测(模型中,X);其他PVPairs =细胞(1、nargin-2);i = 1: nargin-2 PVPairs{1,} =变长度输入宗量{i + 1};结束(varargout {1: nargout}] =预测(模型、X PVPairs {:});结束结束结束

火车一个线性分类模型用部分数据集和创建一个编码器的配置模型。使用编码器配置的属性来指定编码属性的线性模型参数。使用编码器配置的目标函数来生成C代码,预测新的预测数据标签。使用整个数据集,然后再培训模型和更新参数生成的代码没有重新生成代码。

火车模型

加载电离层数据集。这个数据集有34个预测因子和351二进制响应雷达回报,要么坏(“b”)或好(‘g’)。使用一半的火车一个二进制线性分类模型观察。转置的预测数据,并使用“ObservationsIn”名称-值对参数指定的列XTrain对应于观测。

负载电离层rng (“默认”)%的再现性n =长度(Y);c = cvpartition (Y,“坚持”,0.5);idxTrain =培训(c, 1);XTrain = X (idxTrain:) ';YTrain = Y (idxTrain);Mdl = fitclinear (XTrain YTrain,“ObservationsIn”,“列”);

Mdl是一个ClassificationLinear对象。

创建编码器配置

创建一个编码器的配置ClassificationLinear模型通过使用learnerCoderConfigurer。指定的预测数据XTrain,并使用“ObservationsIn”名称-值对参数指定的观察维度XTrain。的learnerCoderConfigurer函数使用这些输入参数来配置相应的编码属性的输入参数预测。同时,设置输出的数量2,这样生成的代码返回预测标签和分数。

配置= learnerCoderConfigurer (Mdl XTrain,“ObservationsIn”,“列”,“NumOutputs”2);

配置是一个ClassificationLinearCoderConfigurer对象,该对象是一个编码器的配置ClassificationLinear对象。

指定编码的属性参数

指定的编码属性线性分类模型参数,这样您就可以更新培训后生成的代码模型中的参数。本例中指定的编码属性预测数据,你想通过对所生成的代码。

指定的编码属性X的属性配置这样生成的代码接受任何数量的观察。修改SizeVectorVariableDimensions属性。的SizeVector属性指定的上界预测数据大小,和VariableDimensions属性指定每个维度的预测数据是否有一个变量大小或固定大小。

configurer.X。SizeVector= [34 Inf]; configurer.X.VariableDimensions
ans =1 x2逻辑阵列0 1

第一维的大小数量的预测变量。这个值必须为一个固定的机器学习模型。因为预测数据包含34个预测因子,的值SizeVector属性的值必须是34和VariableDimensions属性必须0

大小的第二个维度是观测的数量。设置的值SizeVector属性来导致软件更改的值VariableDimensions属性来1。换句话说,大小的上限和大小是可变的,这意味着可以拥有任意数量的观察的预测数据。这个规范是方便如果你不知道观察当生成代码的数量。

维度的顺序SizeVectorVariableDimensions取决于编码器的属性ObservationsIn

configurer.ObservationsIn
ans = EnumeratedInput属性:价值:“列”SelectedOption:“内置”BuiltInOptions:{“行”“列”}IsConstant: 1可调谐性:1

价值的属性ObservationsIn属性是“列”的第一个维度SizeVectorVariableDimensions的属性X对应的数量预测,第二个维度对应于观测的数量。当价值的属性ObservationsIn“行”维度的顺序切换。

生成代码

生成C / c++代码,您必须访问一个C / c++编译器配置正确。MATLAB编码器定位和使用支持,安装编译器。万博1manbetx您可以使用墨西哥人设置查看和更改默认编译器。更多细节,请参阅改变默认的编译器

生成的代码预测更新函数的线性分类模型(Mdl)。

generateCode(配置)
generateCode输出文件夹中创建这些文件:初始化。米”、“预测。米”、“更新。米”、“ClassificationLinearModel。垫的代码生成成功。

generateCode函数完成这些操作:

  • 生成所需的MATLAB文件生成代码,包括两个入口点函数predict.mupdate.m预测更新的功能Mdl,分别。

  • 创建一个墨西哥人函数命名ClassificationLinearModel两个入口点函数。

  • 创建中的墨西哥人功能的代码codegen \墨西哥人\ ClassificationLinearModel文件夹中。

  • 墨西哥人功能复制到当前文件夹。

验证生成的代码

一些预测数据来验证是否通过预测的函数Mdl预测墨西哥人的函数返回相同的标签。在墨西哥人叫一个入口点函数有多个入口点函数,函数名指定为第一个输入参数。

(标签,分数)=预测(Mdl XTrain,“ObservationsIn”,“列”);[label_mex, score_mex] = ClassificationLinearModel (“预测”XTrain,“ObservationsIn”,“列”);

比较标签label_mex通过使用isequal

label_mex isequal(标签)
ans =逻辑1

isequal返回逻辑1 (真正的如果所有的输入都是平等的。确认进行了比较预测的函数Mdl预测墨西哥人的函数返回相同的标签。

比较分数score_mex

马克斯(abs (score-score_mex), [],“所有”)
ans = 0

一般来说,score_mex可能包括舍入差异比较分数。在这种情况下,对比确认分数score_mex是相等的。

重新培训模型和更新参数生成的代码

使用整个数据集训练模型。

retrainedMdl = fitclinear (X, Y)“ObservationsIn”,“列”);

提取参数更新使用validatedUpdateInputs。这个函数修正模型参数的检测retrainedMdl并验证修改后的参数值是否满足编码器的属性参数。

params = validatedUpdateInputs(配置、retrainedMdl);

在生成的代码更新参数。

ClassificationLinearModel (“更新”params)

验证生成的代码

比较的输出预测的函数retrainedMdl预测功能更新的墨西哥人的功能。

(标签,分数)=预测(retrainedMdl X ',“ObservationsIn”,“列”);[label_mex, score_mex] = ClassificationLinearModel (“预测”X ',“ObservationsIn”,“列”);label_mex isequal(标签)
ans =逻辑1
马克斯(abs (score-score_mex), [],“所有”)
ans = 0

比较证实,标签label_mex是相等的,分数值相等。

更多关于

全部展开

版本历史

介绍了R2019b