迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > MATLAB >

MATLAB kstest() 函数详细介绍

作者:迹忆客 最近更新:2023/04/22 浏览次数:

本教程将讨论如何使用 MATLAB 中的 kstest() 函数找到数据集的零假设检验决策,该检验决策用于检查数据集是否来自标准正态分布或不来自标准正态分布。


Matlab kstest() 函数

在 Matlab 中,kstest() 函数用于查找数据集的零假设检验决策,用于检查数据集是否来自标准正态分布或不来自标准正态分布。 kstest() 函数使用单样本 Kolmogorov Smirnov 算法找到测试决策。

kstest() 函数的基本语法如下。

output = kstest(data)

上述语法的输出可以是 0 或 1。如果输出为 0,则函数不拒绝原假设的检验决策,如果输出为 1,则表示函数拒绝检验决策。

让我们讨论一个考试成绩的例子来确认 kstest() 函数的测试决定。 我们可以在单个图上绘制标准正态分布和经验累积分布,以比较它们并确认检验决策。

请参阅下面的示例代码和输出。

clc
clear

load examgrades
data = grades(:,1);
a = (data-75)/10;
testResult = kstest(a)

cdfplot(a)
hold on
x = linspace(min(a),max(a));
plot(x,normcdf(x,0,1),'r--')
legend('Empirical-CDF','Normal-CDF')

输出:

testResult =

  logical

   0

kstest result image 1

我们使用了 examgrades 数据集,它在上面的代码中已经在 Matlab 中。 我们使用了 75 的平均值和 10 的标准偏差来从给定的等级中制作数据集,并将其传递到 kstest() 函数内部,该函数返回 0 作为测试决策值,这意味着该函数没有拒绝 原假设的检验决策。

如果我们查看上面的输出图片,我们可以看到两个分布彼此接近,这证实了测试决策是准确的。 我们使用 cdfplot() 函数绘制数据的累积分布函数,使用 normcdf() 函数找出给定数据的正态分布。

我们已经使用 legend() 函数向图中添加图例以便于理解它。 现在,让我们将上面代码中的平均值从 75 更改为 85 并检查结果。

请参阅下面的示例代码和输出。

clc
clear

load examgrades
data = grades(:,1);
a = (data-85)/10;
testResult = kstest(a)

cdfplot(a)
hold on
x = linspace(min(a),max(a));
plot(x,normcdf(x,0,1),'r--')
legend('Empirical-CDF','Normal-CDF')

输出:

testResult =

  logical

   1

kstest result image 2

上面的代码中,kstest() 函数已经返回了1,表示测试判定被拒绝,我们也可以通过上图来确认,很明显的是两个分布不相等。

我们还可以在使用两列矩阵找到测试决策时指定假设分布。 第一列包含数据,第二列包含累积分布值或 cdf。

我们还必须使用 CDF 参数将其告知 kstest() 函数,如下所示。

output = kstest(data,'CDF',cdfOfData)

在上面的代码中,cdfOfData 是一个双列矩阵,其中第一列是数据,第二列是该数据的 cdf。 我们可以使用 Matlab 的 cdf() 函数找到 cdf。

我们还可以使用概率分布对象指定假设分布,我们可以使用 makedist() 函数创建该对象。 检查此链接以获取有关 makedist() 函数的更多详细信息。

我们必须使用 CDF 参数在 kstest() 函数内部传递分布对象,如下所示。

output = kstest(data,'CDF',cdfObject)

我们还可以使用 Alpha 参数并将其值设置为 0 到 1 来找到不同显着水平的测试决策。 kstest() 函数还将返回一个新参数 p,它显示测试决策的概率。

下面显示了带有 Alpha 参数的 kstest() 函数示例。

[output, p] = kstest(data,'CDF',cdfObject, 'Alpha', 0.2)

我们还可以使用 Tail 参数使用替代假设检查测试决策,其中 kstest() 函数将返回 0 或 1 以支持替代假设。 Tail 参数的值可以不相等、更大或更小。

默认情况下,Tail 参数的值设置为不相等,这意味着总体的 cdf 和假设分布的 cdf 将不相等。 较大的值设置总体的 cdf 大于假设分布的 cdf,较小的值设置总体 cdf 小于假设的 cdf。

下面显示了带有 Tail 参数的 kstest() 函数的示例。

output = kstest(data, 'Tail', 'larger')

kstest() 函数返回四个总参数,如以下语法所示。

[h,p,ksstat,cv] = kstest(data)

我们已经熟悉 kstest() 函数的前两个参数。

ksstat 参数包含假设检验统计量的非负缩放值。 cv 参数具有临界值,一个非负标量。

Matlab还包含 kstest2() 函数,用于使用二样本Kolmogorov Smirnov算法测试两个向量的判定。

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

在 MATLAB 中注释多行

发布时间:2023/04/23 浏览次数:111 分类:MATLAB

可以使用注释块方法或 MATLAB 编辑器在 MATLAB 中注释多行。

MATLAB 最大索引

发布时间:2023/04/23 浏览次数:192 分类:MATLAB

在本教程中,我们将讨论如何使用 MATLAB 中的 max() 函数从数组及其索引中查找最大值。

MATLAB 索引超出矩阵尺寸

发布时间:2023/04/23 浏览次数:103 分类:MATLAB

要解决索引超出矩阵索引的问题,请检查你要获取或替换数据的索引。

MATLAB 检查变量类型

发布时间:2023/04/23 浏览次数:92 分类:MATLAB

在本教程中,我们将讨论如何使用 MATLAB 中的 class() 和 whos 函数检查给定变量的类型。

MATLAB vs Octave

发布时间:2023/04/23 浏览次数:74 分类:MATLAB

我们可以说 Octave 是 MATLAB 的免费版本。

MATLAB MAT 文件

发布时间:2023/04/23 浏览次数:89 分类:MATLAB

可以使用 MAT 文件在 MATLAB 中存储和加载格式化的数据。

MATLAB asv 文件

发布时间:2023/04/23 浏览次数:180 分类:MATLAB

.asv 文件是 MATLAB 生成的自动保存文件,因此在计算机崩溃时你不会丢失数据。

MATLAB 三元运算符

发布时间:2023/04/23 浏览次数:130 分类:MATLAB

MATLAB 中没有三元运算符,因此你必须使用标准格式。

MATLAB & vs &&

发布时间:2023/04/23 浏览次数:134 分类:MATLAB

在 MATLAB 中,&是逻辑与运算符,&&也是表现出短路行为的逻辑运算符。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便