gpt4 book ai didi

r - 按总体平均值划分 data.table 行

转载 作者:行者123 更新时间:2023-12-04 09:42:57 25 4
gpt4 key购买 nike

考虑以下问题

mtcars.dt <- data.table(mtcars)
DT1 = mtcars.dt[, lapply(.SD, mean), by=cyl]
DT2 = mtcars.dt[, lapply(.SD, mean)]

现在,我们有以下值:

> DT1
cyl mpg disp hp drat wt qsec vs am gear carb
1: 6 19.74286 183.3143 122.28571 3.585714 3.117143 17.97714 0.5714286 0.4285714 3.857143 3.428571
2: 4 26.66364 105.1364 82.63636 4.070909 2.285727 19.13727 0.9090909 0.7272727 4.090909 1.545455
3: 8 15.10000 353.1000 209.21429 3.229286 3.999214 16.77214 0.0000000 0.1428571 3.285714 3.500000

> DT2
mpg cyl disp hp drat wt qsec vs am gear carb
1: 20.09062 6.1875 230.7219 146.6875 3.596563 3.21725 17.84875 0.4375 0.40625 3.6875 2.8125

现在,我想将 DT1 中每一行的 mpg、disp、... 归一化为整个原始表的平均值(在 DT2 中可用)。

我该怎么做?这里的正确成语是什么?

编辑:这是所需的输出,抱歉我之前没有更清楚。

    cyl      mpg      disp        hp      drat        wt      qsec       vs        am      gear      carb
1: 6 0.9826900 0.7945249 0.8336478 0.9969837 0.9688843 1.0071934 1.306122 1.0549451 1.0460048 1.2190476
2: 4 1.3271681 0.4556844 0.5633497 1.1318889 0.7104599 1.0721912 2.077922 1.7902098 1.1093991 0.5494949
3: 8 0.7515943 1.5304141 1.4262584 0.8978812 1.2430536 0.9396817 0.000000 0.3516484 0.8910412 1.2444444

最佳答案

这里有一个可能更像 data.table 的解决方案,它使用高效的 set 函数(我使用的是最新的 data.table 版本在 CRAN btw- v 1.9.6 上)

创建DT1

library(data.table) # V 1.9.6+
mtcars.dt <- data.table(mtcars)
DT1 <- mtcars.dt[, lapply(.SD, mean), by = cyl]

现在创建 DT2,同时通过在 .SDcols 参数中取反来避免 cyl

DT2 <- unlist(mtcars.dt[, lapply(.SD, mean), .SDcols = -"cyl"])

现在遍历 DT1 中的第二列并继续更新 DT1 就地 同时除以 DT2

for (j in 2L:length(DT1)) set(DT1, j = j, value = DT1[[j]]/DT2[j - 1L])
DT1
# cyl mpg disp hp drat wt qsec vs am gear carb
# 1: 6 0.9826900 0.7945249 0.8336478 0.9969837 0.9688843 1.0071934 1.306122 1.0549451 1.0460048 1.2190476
# 2: 4 1.3271681 0.4556844 0.5633497 1.1318889 0.7104599 1.0721912 2.077922 1.7902098 1.1093991 0.5494949
# 3: 8 0.7515943 1.5304141 1.4262584 0.8978812 1.2430536 0.9396817 0.000000 0.3516484 0.8910412 1.2444444

关于r - 按总体平均值划分 data.table 行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33397354/

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