diff options
author | Mikhail Galanin <mgalanin@mimecast.com> | 2018-08-20 10:27:12 +0100 |
---|---|---|
committer | Mikhail Galanin <mgalanin@mimecast.com> | 2018-08-20 10:27:12 +0100 |
commit | 5dd0a6b7fb33537a0a80c250502b692175d71581 (patch) | |
tree | 7a105dc7ff307883b792971c930a4b5ce4c3e871 /test/lua | |
parent | 3b5ba9b74e772d9de998350c03e10fb621dc7a3e (diff) | |
download | rspamd-5dd0a6b7fb33537a0a80c250502b692175d71581.tar.gz rspamd-5dd0a6b7fb33537a0a80c250502b692175d71581.zip |
[Minor] Benchmark for lua calls
Diffstat (limited to 'test/lua')
-rw-r--r-- | test/lua/pcall_test.lua | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/test/lua/pcall_test.lua b/test/lua/pcall_test.lua new file mode 100644 index 000000000..26f3ae466 --- /dev/null +++ b/test/lua/pcall_test.lua @@ -0,0 +1,45 @@ +--[[ https://en.wikipedia.org/wiki/Normal_distribution ]] + +-- The Box–Muller method +local function gaussian(mean, variance) + local U = math.random() + local V = math.random() + return math.sqrt(-2.0 * variance * math.log(U)) * + math.cos(2.0 * math.pi * V) + mean +end + +local function mean(t) + local sum = 0 + local count = #t + for i = 1, count do + sum = sum + t[i] + end + return sum / count +end + +local function std(t, mean) + local squares = 0.0 + for i = 1, #t do + local deviation = math.abs(mean - t[i]) + squares = squares + deviation * deviation + end + local variance = squares / #t + return math.sqrt(variance) +end + +local function do_the_call() + local t = {} + local mu = 34.0 + local sigma = 10.0 + + for i = 1, 5 do + table.insert(t, gaussian(mu, sigma)) + end + + return string.format("Got mean: %1.5f, mu: %1.5f\nstd deviance:%1.5f, expected: %1.5f", + mean(t), mu, + std(t, mu), math.sqrt(sigma)) +end + +math.randomseed(os.time()) +return do_the_call |