预测
预测广义线性回归模型的响应
语法
描述
例子
预测响应值
创建一个广义线性回归模型,并预测其对新数据的响应。
使用带有两个基本预测因子的泊松随机数生成样本数据X (: 1)
而且X (:, 2)
.
rng (“默认”)%用于再现性Rndvars = randn(100,2);X = [2 + rndvars(:,1),rndvars(:,2)];= exp(1 + X*[1;2]);Y = poissrnd(mu);
建立泊松数据的广义线性回归模型。
mdl = fitglm(X,y,'y ~ x1 + x2',“分布”,“泊松”);
为预测创建数据点。
[Xtest1,Xtest2] = meshgrid(-1:.5:3,-2:.5:2);Xnew = [Xtest1(:),Xtest2(:)];
预测数据点的反应。
ypred = predict(mdl,Xnew);
绘制预测图。
冲浪(Xtest1 Xtest2,重塑(ypred 9 9))
生成C/ c++预测代码
拟合一个广义线性回归模型,然后使用保存模型saveLearnerForCoder
.定义通过使用加载模型的入口点函数loadLearnerForCoder
并调用预测
拟合模型的功能。然后使用codegen
(MATLAB编码器)生成C/ c++代码。注意,生成C/ c++代码需要MATLAB®Coder™。
这个例子简要地解释了在命令行中预测线性回归模型的代码生成工作流。详情请参见命令行机器学习模型预测的代码生成.您也可以使用MATLAB Coder应用程序生成代码。有关详细信息,请参见利用MATLAB编码器应用程序生成机器学习模型预测的代码.
火车模型
使用带有两个基本预测因子的泊松随机数生成样本数据X (: 1)
而且X (:, 2)
.
rng (“默认”)%用于再现性Rndvars = randn(100,2);X = [2 + rndvars(:,1),rndvars(:,2)];= exp(1 + X*[1;2]);Y = poissrnd(mu);
创建一个广义线性回归模型。指定响应的泊松分布。
mdl = fitglm(X,y,'y ~ x1 + x2',“分布”,“泊松”);
保存模型
将拟合的广义线性回归模型保存到文件中GLMMdl.mat
通过使用saveLearnerForCoder
.
saveLearnerForCoder (mdl“GLMMdl”);
定义入口点函数
在当前文件夹中,定义名为mypredictGLM.m
它的作用如下:
接受新的预测器输入和有效的名值对参数。
加载拟合的广义线性回归模型
GLMMdl.mat
通过使用loadLearnerForCoder
.返回预测和置信区间边界。
函数[yhat,ci] = mypredictGLM(x,varargin)% # codegenMYPREDICTGLM使用GLM模型预测响应% MYPREDICTGLM预测n × 1矩阵中n个观测值的响应%向量x使用存储在mat文件GLMMdl.mat中的GLM模型,%,然后返回n × 1向量yhat中的预测结果。的置信区间边界%的预测在n × 2向量ci。CompactMdl = loadLearnerForCoder(“GLMMdl”);narginchk(正);[yhat,ci] = predict(CompactMdl,x,varargin{:});结束
添加% # codegen
编译器指令(或pragma)到函数入口点之后的函数签名,以表明您打算为MATLAB算法生成代码。添加此指令将指导MATLAB代码分析器帮助您诊断和修复在代码生成过程中可能导致错误的违规行为。
生成代码
生成入口点函数的代码codegen
(MATLAB编码器).因为C和c++都是静态类型语言,所以必须在编译时确定入口点函数中所有变量的属性。要指定数据类型和精确的输入数组大小,请传递一个MATLAB®表达式,该表达式表示具有特定数据类型和数组大小的值集。使用编码器。常数
(MATLAB编码器)用于名称-值对参数的名称。
为预测创造点数。
[Xtest1,Xtest2] = meshgrid(-1:.5:3,-2:.5:2);Xnew = [Xtest1(:),Xtest2(:)];
生成代码并指定在预测上返回90%的同步置信区间。
codegenmypredictGLMarg游戏{Xnew, coder.Constant(α),0.1,coder.Constant(同步),真正的}
代码生成成功。
codegen
生成MEX函数mypredictGLM_mex
使用依赖于平台的扩展。
如果在编译时观察数未知,您还可以使用将输入指定为可变大小coder.typeof
(MATLAB编码器).详细信息请参见为代码生成指定可变大小的参数而且指定入口点函数输入的属性(MATLAB编码器).
验证生成的代码
比较预测和置信区间使用预测
而且mypredictGLM_mex
.属性中指定名称-值对参数的顺序与arg游戏
的调用中的参数codegen
.
[yhat1,ci1] = predict(mdl,Xnew,“α”, 0.1,“同时”,真正的);[yhat2,ci2] = mypredictGLM_mex(Xnew,“α”, 0.1,“同时”,真正的);
返回的值mypredictGLM_mex
的值可能包含四舍五入的差异预测
.在这种情况下,比较允许小公差的值。
Find (abs(yhat1-yhat2) > 1e-6)
Ans = 0x1空双列向量
Find (abs(ci1-ci2) > 1e-6)
Ans = 0x1空双列向量
比较确认返回值在公差范围内相等1 e-6
.
输入参数
mdl
- - - - - -广义线性回归模型
GeneralizedLinearModel
对象|CompactGeneralizedLinearModel
对象
广义线性回归模型,指定为GeneralizedLinearModel
使用fitglm
或stepwiseglm
,或CompactGeneralizedLinearModel
使用紧凑的
.
Xnew
- - - - - -新的预测器输入值
表格|数据集的数组|矩阵
新的预测器输入值,指定为表、数据集数组或矩阵。每行Xnew
对应一个观察结果,每一列对应一个变量。
如果
Xnew
是表或数据集数组,则它必须包含与PredictorNames
的属性mdl
.如果
Xnew
是一个矩阵,它必须有相同数量的变量(列)在相同的顺序预测器输入用于创建mdl
.请注意,Xnew
还必须包含在拟合模型中未用作预测因子的任何预测变量。此外,所有变量在创建mdl
必须是数字。要将数值预测器视为分类的,请使用“CategoricalVars”
参数的名称-值对mdl
.
数据类型:单
|双
|表格
名称-值参数
指定可选参数对为Name1 = Value1,…,以=家
,在那里名字
参数名称和价值
对应的值。名称-值参数必须出现在其他参数之后,但对的顺序无关紧要。
在R2021a之前,使用逗号分隔每个名称和值,并将其括起来名字
在报价。
例子:[ypred,yci] = predict(Mdl,Xnew,'Alpha',0.01,'Simultaneous',true)
返回置信区间开办
99%的置信水平,同时计算所有预测值。
α
- - - - - -显著性水平
0.05(默认)|范围为[0,1]的数值
置信区间的显著性级别,指定为由逗号分隔的对组成“α”
和范围[0,1]中的数值。的置信水平开办
等于100 (1 -α
) %.α
是置信区间不包含真实值的概率。
例子:“阿尔法”,0.01
数据类型:单
|双
BinomialSize
- - - - - -二项分布的试验次数
1(默认)|标量|向量
二项分布的试验次数,指定为逗号分隔的对,由“BinomialSize”
和一个与响应长度相同的标量或向量。预测
将标量输入展开为与响应大小相同的常量数组。标量输入意味着所有观测值都有相同的试验次数。
中的输出值的含义ypred
取决于的值“BinomialSize”
.
如果
“BinomialSize”
是1(默认),那么输出中的每个值ypred
是成功的概率。如果
“BinomialSize”
是不是1,那么每个值都在输出ypred
是试验中预测的成功数。
数据类型:单
|双
抵消
- - - - - -偏移值
0(大小(Xnew,1))
(默认)|标量|向量
中的每一行的偏移值Xnew
,指定为逗号分隔的对,由“抵消”
和一个与响应长度相同的标量或向量。预测
将标量输入展开为与响应大小相同的常量数组。
注意,此参数的默认值是一个0向量,即使您指定“抵消”
拟合模型时的名称-值对参数。如果你指定“抵消”
为了拟合,软件将偏移量作为一个附加的预测因子,其系数值固定为1。换句话说,拟合公式是
f(μ)=偏移量+X*b
,
在哪里f是连杆函数,μ平均响应,和X*b预测因子是线性组合吗X.的抵消
预测器有系数1
.
数据类型:单
|双
同时
- - - - - -标记来计算同时的置信范围
假
(默认)|真正的
标志,以计算同时的置信范围,指定为逗号分隔的对,由“同时”
不是真就是假。
真正的
- - - - - -预测
中所有预测值对应的响应值曲线计算置信界限Xnew
,使用Scheffe方法。上界和下界之间的范围包含由100(1 - α)%置信度的真实响应值组成的曲线。假
- - - - - -预测
中每个观测点的响应值计算置信范围Xnew
.响应值在特定预测值处的置信区间包含具有100(1 - α)%置信度的真实响应值。
同时边界比单独边界宽,因为要求响应值的整个曲线在边界内比要求单个预测值的响应值在边界内更严格。
例子:“同步”,真的
输出参数
选择功能
扩展功能
C/ c++代码生成
使用MATLAB®Coder™生成C和c++代码。
使用注意事项和限制:
使用
saveLearnerForCoder
,loadLearnerForCoder
,codegen
(MATLAB编码器)方法生成代码预测
函数。通过使用保存一个训练好的模型saveLearnerForCoder
.定义一个入口点函数,该函数通过loadLearnerForCoder
并调用预测
函数。然后使用codegen
为入口点函数生成代码。该表包含关于的参数的注释
预测
.完全支持不包括在本表中的参数。金宝app论点 注意事项和限制 mdl
有关模型对象的使用说明和限制,请参见代码生成的
CompactGeneralizedLinearModel
对象。Xnew
Xnew
必须是单精度或双精度矩阵或包含数值变量、类别变量或两者的表。的行数,或观测值
Xnew
可以是大小可变的,但列的数量呢Xnew
必须修复。如果你想指定
Xnew
作为一个表,那么你的模型必须使用一个表来训练,你必须确保你的预测入口点函数:以数组形式接受数据
根据数据输入参数创建一个表,并指定表中的变量名
把表格传给
预测
有关此表工作流的示例,请参见生成代码对表中的数据进行分类.有关在代码生成中使用表的详细信息,请参见表的代码生成(MATLAB编码器)而且代码生成的表限制(MATLAB编码器).
名-值对参数 名称-值参数中的名称必须是编译时常量。例如,要允许在生成的代码中使用用户定义的重要级别,请使用include
{coder.Constant(α),0}
在arg游戏
的价值codegen
(MATLAB编码器).
有关更多信息,请参见代码生成简介.
GPU数组
通过使用并行计算工具箱™在图形处理单元(GPU)上运行来加速代码。
本功能完全支持GPU阵列。金宝app有关更多信息,请参见在图形处理器上运行MATLAB函数(并行计算工具箱).
版本历史
在R2012a中引入
MATLAB命令
你点击了一个对应于这个MATLAB命令的链接:
在MATLAB命令窗口中输入该命令来运行该命令。Web浏览器不支持MATLAB命令。金宝app
您也可以从以下列表中选择一个网站:
如何获得最佳的网站性能
选择中国站点(中文或英文)以获得最佳站点性能。其他MathWorks国家站点没有针对您所在位置的访问进行优化。