- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 R 包 leaps
在单个因变量和超过 50 个可能的预测变量上运行所有可能的回归模型组合——所有可能的大小。每个变量都是一个包含大约 50 个数值的向量。
这是我尝试过但没有成功的方法:
vars <- c("var1", "var2", "var3", ... , "var60")
xs <- as.formula(paste("yvar ~ ", paste(vars, collapse="+")))
model1 <- regsubsets(x=xs, y=yvar, really.big=TRUE,
method="exhaustive", data=data)
summary(model1)
我收到的错误是:
Warning message:
In leaps.setup(x, y, wt = wt, nbest = nbest, nvmax = nvmax, force.in = force.in,:
15 linear dependencies found
最佳答案
这里有几个问题与您尝试做的事情有关,一些是计算性的,一些是统计性的。评论中已经提到了一些,但我认为将它们全部放在一个答案中是很好的。
首先,对于 50 个可能的预测变量,有 $2^50$ 个可能的模型(当以 10 为基数表示时,这是一个 16 位数字):
> 2^50
[1] 1.1259e+15
虽然算法中有一些不错的捷径,但每个可能的模型仍然需要一些时间来计算(以及一些内存来存储结果)。如果我们假设您的计算机每秒可以计算 100,000 个模型,那么它只需要 356 年以上的时间就可以完成(假设您的计算机没有开始交换内存来保留所有结果,这确实会减慢速度):
> 2^50/100000/60/60/24/365.24
[1] 356.7859
所以我建议坚持使用“最佳”模型,而不是尝试适应所有可能的模型。
另一个问题(这是导致警告消息的原因)是,如果您只有 50 个观测值(“每个变量是一个包含大约 50 个数值的向量”),那么您可以唯一估计的绝对最大斜率数 (假设您还拟合了一个截距)是 49,但是您正试图在最完整的模型中拟合 50 个斜率,因此所涉及的矩阵保证是奇异的。即使限制为 49 个预测变量也不允许估计误差方差。一个常见的经验法则表明,您应该尝试为每 10 个观测值拟合不超过 1 个预测变量,以便获得对斜率和标准误差的合理估计,这意味着您实际上应该只使用最多 5 个预测变量模型(如果您确实有50 个观察值,您描述中的“大约”意味着缺失值或其他问题可能会使这个值变得更少)。
从最佳子集回归中学到的最好的东西不是“最佳”模型是什么,而是很少有“最佳”模型,并且多个模型可能具有类似的良好属性。更好的方法可能是使用 Lasso/LARS 样式拟合(取决于您真正想要回答的问题)。
future 的一些编程技巧:
了解用于指定模型的 y ~ .
方法,这可能使您无需担心使用 paste
和 as.formula
.
引用您的数据名称,请参阅 fortune(77)
。
关于r - 飞跃 : Running all possible linear models,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32213547/
我对 mongoosejs 中模型的使用感到有些困惑。 可以通过这些方式使用 mongoose 创建模型 使用 Mongoose var mongoose = require('mongoose');
我正在看 from django.db import models class Publisher(models.Model): name = models.CharField(max_len
我有自己的 html 帮助器扩展,我用这种方式 model.Reason_ID, Register.PurchaseReason) %> 这样声明的。 public static MvcHtmlS
假设模型原本是存储在CPU上的,然后我想把它移到GPU0上,那么我可以这样做: device = torch.device('cuda:0') model = model.to(device) # o
我过去读过一些关于模型的 MVC 建议,指出不应为域和 View 重用相同的模型对象;但我找不到任何人愿意讨论为什么这很糟糕。 我认为创建两个单独的模型 - 一个用于域,一个用于 View - 然后在
我正在使用pytorch构建一个像VGG16这样的简单模型,并且我已经重载了函数forward在我的模型中。 我发现每个人都倾向于使用 model(input)得到输出而不是 model.forwar
tf.keras API 中的 models 是否多余?对于某些情况,即使不使用 models,代码也能正常运行。 keras.models.sequential 和 keras.sequential
当我尝试使用 docker 镜像运行 docker 容器时遇到问题:tensorflow/serving。 我运行命令: docker run --name=tf_serving -it tensor
我有一个模型,我用管道注册了它: register_step = PythonScriptStep(name = "Register Model",
如果 View 需要访问模型中的数据,您是否认为 Controller 应: a)将模型传递给 View b)将模型的数据传递给 View c)都不;这不应该是 Controller 所关心的。让 V
我正在寻找一个可以在模型中定义的字段,该字段本质上是一个列表,因为它将用于存储多个字符串值。显然CharField不能使用。 最佳答案 您正在描述一种多对一的关系。这应该通过一个额外的 Model 进
我最近了解了 Django 中的模型继承。我使用很棒的包 django-model-utils 取得了巨大的成功。我继承自 TimeStampedModel 和 SoftDeletableModel。
我正在使用基于 resnet50 的双输出模型进行项目。一个输出用于回归任务,第二个输出用于分类任务。 我的主要问题是关于模型评估。在训练期间,我在验证集的两个输出上都取得了不错的结果: - 综合损失
我是keras的新手。现在,我将使用我使用 model.fit_generator 训练的模型来预测测试图像组。我可以使用 model.predict 吗?不确定如何使用model.predict_g
在 MVC 应用程序中,我加入了多个表并将其从 Controller 返回到 View,如下所示: | EmployeeID | ControlID | DoorAddress | DoorID |
我在使用 sails-cassandra 连接系统的 Sails 中有一个 Data 模型。数据。 Data.count({...}).exec() 返回 1,但 Data.find({...}).e
我正在使用 PrimeFaces dataTable 开发一个 jsf 页面来显示用户列表。用户存储在 Model.User 类的对象中。
我正在关注https://www.tensorflow.org/tutorials/keras/basic_classification解决 Kaggle 挑战。 但是,我不明白应该将什么样的数据输入
我是这个领域的新手。那么,你们能帮忙如何为 CNN 创建 .config 文件吗? 传递有关如何执行此操作的文档或教程将对我有很大帮助。谢谢大家。 最佳答案 这个问题对我来说没有多大意义,因为 .co
我是“物理系统建模”主题的新手。我阅读了一些基础文献,并在 Modelica 和 Simulink/Simscape 中做了一些教程。我想问你,如果我对以下内容理解正确: 符号操作是将微分代数方程组(
我是一名优秀的程序员,十分优秀!