diff options
Diffstat (limited to 'vec2-averages.lua')
-rwxr-xr-x | vec2-averages.lua | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/vec2-averages.lua b/vec2-averages.lua new file mode 100755 index 0000000..94247e9 --- /dev/null +++ b/vec2-averages.lua @@ -0,0 +1,51 @@ +#!/usr/bin/env lua +local eyes = require "eyes" +local format = require "format" +local reading = require "reading" +local vec2 = require "cpml".vec2 +local readout = { + [0] = vec2.new{ 0, 0}, + [1] = vec2.new{ 0, 1}, + [2] = vec2.new{ 1, 0}, + [3] = vec2.new{ 0, -1}, + [4] = vec2.new{-1, 0}, +} +local translation = { + [0] = vec2.new{0, 0}, + [1] = vec2.new{0, 1}, + [2] = vec2.new{0.447, 0.894}, + [3] = vec2.new{0.707, 0.707}, + [4] = vec2.new{0.894, 0.447}, + [5] = vec2.new{1, 0}, + [6] = vec2.new{0.894, -0.447}, + [7] = vec2.new{0.707, -0.707}, + [8] = vec2.new{0.447, -0.894}, + [9] = vec2.new{0, -1}, + [10] = vec2.new{-0.447, -0.894}, + [11] = vec2.new{-0.707, -0.707}, + [12] = vec2.new{-0.894, -0.447}, + [13] = vec2.new{-1, 0}, + [14] = vec2.new{-0.894, 0.447}, + [15] = vec2.new{-0.707, 0.707}, + [16] = vec2.new{-0.447, 0.894}, +} + + +function translate (v) + for i, r in pairs(translation) do -- Lookup would use floating point equality... + if vec2.dist(r, v) < 0.01 then + return i + end + end + error "unexpected vec2" +end + + +for _, message in ipairs(eyes) do + local values = {} + for _, a, b, c in reading.trigrams(message) do + local v = readout[a] + readout[b] + readout[c] + table.insert(values, translate(v:normalize())) + end + print(format.csv(values)) +end |