আমি sample
আর তে ফাংশনটি বেঞ্চমার্ক করছিলাম এবং এর সাথে তুলনা করে igraph:sample_seq
একটি অদ্ভুত ফলাফলের দিকে চলে এসেছি ।
যখন আমি এই জাতীয় কিছু চালাই:
library(microbenchmark)
library(igraph)
set.seed(1234)
N <- 55^4
M <- 500
(mbm <- microbenchmark(v1 = {sample(N,M)},
v2 = {igraph::sample_seq(1,N,M)}, times=50))
আমি এর মত একটি ফলাফল পেয়েছি:
Unit: microseconds
expr min lq mean median uq max neval
v1 21551.475 22655.996 26966.22166 23748.2555 28340.974 47566.237 50
v2 32.873 37.952 82.85238 81.7675 96.141 358.277 50
তবে আমি যখন দৌড়ে যাই, উদাহরণস্বরূপ,
set.seed(1234)
N <- 100^4
M <- 500
(mbm <- microbenchmark(v1 = {sample(N,M)},
v2 = {igraph::sample_seq(1,N,M)}, times=50))
আমি এর জন্য আরও দ্রুত ফলাফল পেয়েছি sample
:
Unit: microseconds
expr min lq mean median uq max neval
v1 52.165 55.636 64.70412 58.2395 78.636 88.120 50
v2 39.174 43.504 62.09600 53.5715 73.253 176.419 50
দেখে মনে হচ্ছে যে যখন N
10 (বা অন্য কোনও বিশেষ সংখ্যা?) একটি পাওয়ার হয় তখন অন্য sample
ছোটগুলির তুলনায় খুব দ্রুত N
হয় যেগুলি 10 এর শক্তি নয় this এই প্রত্যাশিত আচরণটি নাকি আমি কোনও কিছু মিস করছি?