আর স্ক্রিপ্ট চালাচ্ছে
আমি একটি ফাইলের নামের যুক্তি নিতে এবং লাইনগুলি যোগ করতে একটি আর স্ক্রিপ্ট লিখেছি।
#! /usr/local/bin/R
file=commandArgs(trailingOnly=TRUE)[1]
sum(as.numeric(readLines(file)))
এটি "ডেটা টেটেবল" বা "ভ্রুম" প্যাকেজটি নিম্নরূপভাবে বাড়িয়ে দেওয়া যেতে পারে:
#! /usr/local/bin/R
file=commandArgs(trailingOnly=TRUE)[1]
sum(data.table::fread(file))
#! /usr/local/bin/R
file=commandArgs(trailingOnly=TRUE)[1]
sum(vroom::vroom(file))
স্থির করা মাপকাঠি
@ বেগেন জ্যাকম্যান হিসাবে একই বেঞ্চমার্কিং ডেটা ।
for ((i=0; i<1000000; i++)) ; do echo $RANDOM; done > random_numbers
উপরের আর কলটির তুলনায়, স্ক্রিপ্ট হিসাবে আর 3.5.0 চালানো অন্যান্য পদ্ধতির সাথে (একই লিনাক্স ডেবিয়ান সার্ভারে) তুলনাযোগ্য ble
$ time R -e 'sum(scan("random_numbers"))'
0.37s user
0.04s system
86% cpu
0.478 total
রিডলাইনস সহ আর স্ক্রিপ্ট
$ time Rscript sum.R random_numbers
0.53s user
0.04s system
84% cpu
0.679 total
Data.table সহ আর স্ক্রিপ্ট
$ time Rscript sum.R random_numbers
0.30s user
0.05s system
77% cpu
0.453 total
ভর্ম সহ আর স্ক্রিপ্ট
$ time Rscript sum.R random_numbers
0.54s user
0.11s system
93% cpu
0.696 total
অন্যান্য ভাষার সাথে তুলনা
রেফারেন্সের জন্য একই হার্ডওয়্যারে প্রস্তাবিত কিছু অন্যান্য পদ্ধতি হিসাবে
পাইথন 2 (2.7.13)
$ time python2 -c "import sys; print sum((float(l) for l in sys.stdin))" < random_numbers
0.27s user 0.00s system 89% cpu 0.298 total
পাইথন 3 (3.6.8)
$ time python3 -c "import sys; print(sum((float(l) for l in sys.stdin)))" < random_number
0.37s user 0.02s system 98% cpu 0.393 total
রুবি (২.৩.৩)
$ time ruby -e 'sum = 0; File.foreach(ARGV.shift) {|line| sum+=line.to_i}; puts sum' random_numbers
0.42s user
0.03s system
72% cpu
0.625 total
পার্ল (5.24.1)
$ time perl -nle '$sum += $_ } END { print $sum' random_numbers
0.24s user
0.01s system
99% cpu
0.249 total
অজগর (৪.১.৪)
$ time awk '{ sum += $0 } END { print sum }' random_numbers
0.26s user
0.01s system
99% cpu
0.265 total
$ time awk '{ sum += $1 } END { print sum }' random_numbers
0.34s user
0.01s system
99% cpu
0.354 total
সি (ঝনঝন সংস্করণ 3.3; জিসিসি (দেবিয়ান 6.3.0-18) 6.3.0)
$ gcc sum.c -o sum && time ./sum < random_numbers
0.10s user
0.00s system
96% cpu
0.108 total
অতিরিক্ত ভাষা সহ আপডেট করুন
লুয়া (5.3.5)
$ time lua -e 'sum=0; for line in io.lines() do sum=sum+line end; print(sum)' < random_numbers
0.30s user
0.01s system
98% cpu
0.312 total
টিআর (৮.২ b) অবশ্যই বাশে সময়সই হতে হবে, zsh এর সাথে সামঞ্জস্যপূর্ণ নয়
$time { { tr "\n" + < random_numbers ; echo 0; } | bc; }
real 0m0.494s
user 0m0.488s
sys 0m0.044s
সেড (৪.৪) অবশ্যই ব্যাশের সাথে সময়সই করা উচিত, zsh এর সাথে সামঞ্জস্যপূর্ণ নয়
$ time { head -n 10000 random_numbers | sed ':a;N;s/\n/+/;ta' |bc; }
real 0m0.631s
user 0m0.628s
sys 0m0.008s
$ time { head -n 100000 random_numbers | sed ':a;N;s/\n/+/;ta' |bc; }
real 1m2.593s
user 1m2.588s
sys 0m0.012s
দ্রষ্টব্য: সেড কলগুলি আরও মেমরির উপলব্ধ সিস্টেমগুলিতে দ্রুত কাজ করে বলে মনে হচ্ছে (বেঞ্চমার্কিং সেডের জন্য ব্যবহৃত ছোট ছোট ডেটাসেটগুলি নোট করুন)
জুলিয়া (০.০.০)
$ time julia -e 'print(sum(readdlm("random_numbers")))'
3.00s user
1.39s system
136% cpu
3.204 total
$ time julia -e 'print(sum(readtable("random_numbers")))'
0.63s user
0.96s system
248% cpu
0.638 total
লক্ষ করুন যে আর এর মতো ফাইল আই / ও পদ্ধতিতে ভিন্ন ভিন্ন কর্মক্ষমতা রয়েছে।