我正在尝试使用以下代码缩放0和1范围内的data.frame:
for(i in 1:nrow(data))
{
x <- data[i, ]
data[i, ] <- scale(x, min(x), max(x)-min(x))
}
Data:
x1 x2 x3 x4 x5 x6 x7 x8 x9 x10 x11 x12 x13 x14 x15 x16 x17
15 6 6 0 9 3 1 4 5 1 1 13 0 0 20 5 28
2 24 14 7 0 15 7 0 11 3 3 4 15 7 0 30 0 344
3 10 5 2 0 6 2 0 5 0 0 2 7 1 0 11 0 399
4 9 4 2 0 5 2 0 4 0 0 2 6 1 0 10 0 28
5 6 2 1 0 3 1 0 2 0 0 1 3 1 0 6 0 82
6 9 4 2 0 5 2 0 4 0 0 2 6 1 0 10 0 42
Run Code Online (Sandbox Code Playgroud)
但我收到以下错误消息:
Error in scale.default(x, min(x), max(x) - min(x)) (from #4) :
length of 'center' must equal the number of columns of 'x'
Run Code Online (Sandbox Code Playgroud)
使用这些数据,您的示例适合我:
data <- matrix(sample(1:1000,17*6), ncol=17,nrow=6)
for(i in 1:nrow(data)){
x <- data[i, ]
data[i, ] <- scale(x, min(x), max(x)-min(x))
}
Run Code Online (Sandbox Code Playgroud)
这里使用scale的另一个选项,没有循环.您只需要为矩阵提供一个scale和一个center相同的列.
maxs <- apply(data, 2, max)
mins <- apply(data, 2, min)
scale(data, center = mins, scale = maxs - mins)
Run Code Online (Sandbox Code Playgroud)
编辑如何访问结果.
比例返回一个包含2个属性的矩阵.要获取data.frame,您只需将比例结果强制转换为data.frame即可.
dat.scale <- scale(data, center = mins, scale = maxs - mins)
dat.sacle <- as.data.frame(dat.scale)
Run Code Online (Sandbox Code Playgroud)