Windows 7下64位R的优化问题

如何解决Windows 7下64位R的优化问题

| 我目前处于开发我的第一个R包的最后阶段,该R包应该适合多项处理树(MPT)模型(有关当前版本,请参见其主页)。通过R \的“ 0”功能实现模型拟合。 今天,我第一次在Windows 7机器上玩它,并发现了一些非常奇怪的东西:当使用64位版本的R时,
optim
无法成功收敛。这对我来说似乎是一个错误(尤其是
nlminb
都收敛了) R版本)。由于ѭ0是我程序包的核心,因此非常感谢您提供有关此问题的帮助。 这是一个最小可复制的示例(通常,模型是通过表达式指定的,而不是在目标函数中指定的,但是为了简单起见,我将所有内容都放在了目标函数中):
# The objective function:
llk.tree <- function (Q,data) 
{
    p <- Q[1]
    q <- Q[2]
    r <- Q[3]
    e <- rep(NA,4)
    e[1] <- p * q * r
    e[2] <- p * q * (1-r)
    e[3] <- p * (1-q) * r
    e[4] <- p * (1-q) * (1-r) + (1-p)

    llk <- sum(data * log(e))
    if (is.na(llk)) 
        llk <- -1e+19
    if (llk == -Inf) 
        llk <- -1e+19
    return(-llk)
}

# The call to optim:
optim(runif(3,0.1,0.9),llk.tree,data = c(24,65,30,61),method = \"L-BFGS-B\",lower = rep(0,3),upper = rep(1,3))
此示例复制了Riefer&Batchelder关于MPT的开创性论文的示例,即表1 p中的第1行。 327(预期参数值为p = 1,q = 0.49,r = 0.30)。 在32位R上运行它总是可以得到正确的结果(与版本2.12.2和2.13.0一起尝试):
$par
[1] 1.0000000 0.4944449 0.3000001

$value
[1] 234.7110

$counts
function gradient 
      11       11 

$convergence
[1] 0

$message
[1] \"CONVERGENCE: REL_REDUCTION_OF_F <= FACTR*EPSMCH\"
(请注意,由于随机起始值,计数可能有所不同。) 另一方面,在64位R上运行它可能会产生这样的(错误)结果:
$par
[1] 0.8668081 0.6326655 0.1433857

$value
[1] 257.7328

$counts
function gradient 
       3        3 

$convergence
[1] 0

$message
[1] \"CONVERGENCE: REL_REDUCTION_OF_F <= FACTR*EPSMCH\"
每次运行时,目标函数的返回值和参数值均不同,但计数始终为3! 请注意,运行bit2ѭ会在32位和64位R上产生正确的结果:
nlminb(runif(3,lower = 0,upper = 1)

$par
[1] 1.0000000 0.4944445 0.3000000

$objective
[1] 234.711

$convergence
[1] 0

$iterations
[1] 14

$evaluations
function gradient 
      19       55 

$message
[1] \"relative convergence (4)\"
最后一点:我们有一些示例(这是我们最简单的示例模型),适用于64位R和
optim
,但更多示例(如此处所示的示例)不起作用。 计数总是3 ... 编辑: 固定起始值时(感谢约书亚·乌尔里希(Joshua Ulrich))
optim
不会偏离64位R下的那些固定值:
optim(c(0.5,0.5,0.5),3))

$par
[1] 0.5 0.5 0.5

$value
[1] 276.1238

$counts
function gradient 
       3        3 

$convergence
[1] 0

$message
[1] \"CONVERGENCE: REL_REDUCTION_OF_F <= FACTR*EPSMCH\"

解决方法

今天我们进行了更多测试,发现与使用64位R的Linux下的问题中描述的问题相同。 但是,由于Joachim Vandekerckhove提出了这个巧妙的想法,我们尝试了一个简单的更改来解决了这个问题(尽管问题仍然很可疑)。在目标函数的末尾,如果
llk
Inf
,我们将其设置为极高的值(原为
1e19
)。 使用较小的值(例如
1e10
)可以解决64位计算机上的问题(到目前为止已在Linux上进行了测试):
llk.tree <- function (Q,data) 
{
    p <- Q[1]
    q <- Q[2]
    r <- Q[3]
    e <- rep(NA,4)
    e[1] <- p * q * r
    e[2] <- p * q * (1-r)
    e[3] <- p * (1-q) * r
    e[4] <- p * (1-q) * (1-r) + (1-p)

    llk <- sum(data * log(e))
    if (is.na(llk)) 
        llk <- -1e+10
    if (llk == -Inf) 
        llk <- -1e+10
    return(-llk)
}

# The call to optim:
optim(runif(3,0.1,0.9),llk.tree,data = c(24,65,30,61),method = \"L-BFGS-B\",lower = rep(0,3),upper = rep(1,3))
这将返回正确的结果!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-