gpt4 book ai didi

r - 匹配不起作用

转载 作者:行者123 更新时间:2023-12-01 10:54:15 25 4
gpt4 key购买 nike

我试图将数字与向量匹配,如下所示:

t <- seq(-4,4,length=81)

tifl.e <--1.5
tifc.e <--0.5
tifr.e <-0.5
tifl.m <--1.6
tifc.m <--0.4
tifr.m <-0.8

match( c(tifl.e, tifc.e, tifr.e), t)
[1] 26 36 46
match( c(tifl.m, tifc.m, tifr.m), t)
[1] NA NA NA

我也尝试了代码,但它给出了相同的结果。

tifl.cut <-c(-1.5,-1.6)
tifc.cut <-c(-0.5,-0.4)
tifr.cut <-c(0.5,0.8)

match( c(tifl.cut[1], tifc.cut[1], tifr.cut[1]), t)
[1] 26 36 46
match( c(tifl.cut[2], tifc.cut[2], tifr.cut[2]), t)
[1] NA NA NA

与此同时,我使用 %in% 尝试了类似的语法,结果完全相同。

那么语法上有什么问题呢?我该如何解决?

感谢您的投入。

最佳答案

处理浮点错误的正确方法是使用all.equal。这是一个自定义函数,用于将 match 应用于数字并考虑浮点错误的可能性:

match.numeric <- function(x, table) {
are.equal <- function(x, y) isTRUE(all.equal(x, y))
match.one <- function(x, table)
match(TRUE, vapply(table, are.equal, logical(1L), x = x))
vapply(x, match.one, integer(1L), table)
}

match.numeric(c(tifl.e, tifc.e, tifr.e), t)
# [1] 26 36 46
match.numeric(c(tifl.m, tifc.m, tifr.m), t)
# [1] 25 37 49

关于r - 匹配不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16309750/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com