大量のデータを生成し、それを R でキャッチすることを期待しています。行数、列数、および変数タイプによって、data.frame のサイズ (したがって必要なメモリ) を推定するにはどうすればよいですか?
例。
10000 行と 150 列があり、そのうち 120 が数値、20 が文字列、10 が因子レベルである場合、期待できるデータ フレームのサイズはどれくらいですか? 列に格納されているデータによって結果が変わるか (のようにmax(nchar(column))
)?
> m <- matrix(1,nrow=1e5,ncol=150)
> m <- as.data.frame(m)
> object.size(m)
120009920 bytes
> a=object.size(m)/(nrow(m)*ncol(m))
> a
8.00066133333333 bytes
> m[,1:150] <- sapply(m[,1:150],as.character)
> b=object.size(m)/(nrow(m)*ncol(m))
> b
4.00098133333333 bytes
> m[,1:150] <- sapply(m[,1:150],as.factor)
> c=object.size(m)/(nrow(m)*ncol(m))
> c
4.00098133333333 bytes
> m <- matrix("ajayajay",nrow=1e5,ncol=150)
>
> m <- as.data.frame(m)
> object.size(m)
60047120 bytes
> d=object.size(m)/(nrow(m)*ncol(m))
> d
4.00314133333333 bytes