首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >QQ图的编程实现

QQ图的编程实现
EN

Stack Overflow用户
提问于 2011-11-12 19:25:42
回答 2查看 1.2K关注 0票数 6

我有一份男女学生的数学考试成绩样本。我想画出每个性别的QQ图,看看它们是否都是正态分布的。我知道如何绘制整体样本的QQ图,但如何分别绘制它们?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-11-12 20:00:29

下面是一个使用base显卡的简单解决方案:

代码语言:javascript
复制
scores <- rnorm(200, mean=12, sd=2)
gender <- gl(2, 50, labels=c("M","F"))
opar <- par(mfrow=c(1,2))
for (g in levels(gender))
  qqnorm(scores[gender==g], main=paste("Gender =", g))
par(opar)

然后是更优雅的lattice解决方案:

代码语言:javascript
复制
qqmath(~ scores | gender, data=data.frame(scores, gender), type=c("p", "g"))

有关可能的自定义的更多讨论和示例,请参阅qqmath的在线帮助。

票数 5
EN

Stack Overflow用户

发布于 2020-10-29 02:51:21

在Python语言中,有一个由OpenTURNS库see doc here提供的QQplot方法。下面是一个例子。

在第一步中,我们从均匀分布中生成大小为300的随机样本。

在第二步中,我们认为我们不知道这个样本来自哪里,并尝试拟合正态分布和均匀分布。

在第三步中,我们绘制样本对每个拟合分布的QQPlot,以便“看”哪个分布是最好的。

第一步:

代码语言:javascript
复制
import openturns as ot
from openturns.viewer import View
    
distribution = ot.Uniform(-1, 1)
sample = distribution.getSample(300)

第二步:

代码语言:javascript
复制
fitted_normal = ot.NormalFactory().build(sample)
fitted_uniform = ot.UniformFactory().build(sample)

第三步:

代码语言:javascript
复制
QQ_plot1 = ot.VisualTest.DrawQQplot(sample, fitted_normal)
QQ_plot2 = ot.VisualTest.DrawQQplot(sample,fitted_uniform)
    
View(QQ_plot1)
View(QQ_plot2)

正如预期的那样,拟合的均匀更适合在域的两端具有较大误差的法线样本。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8104321

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档