blob: 98bc73c3bc0e277516302a9e3d2b714a8db59f9b (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
(.using
[library
[lux "*"
["_" test {"+" Test}]
[abstract
[monad {"+" do}]]
[math
["[0]" random]
[number
["i" int]]]]]
[\\library
["[0]" /]])
(template: (!quadrance/2 m0 m1)
[(i.+ (i.* m0 m0) (i.* m1 m1))])
(/.inline: .public (quadrance/2 m0 m1)
(-> Int Int Int)
(!quadrance/2 m0 m1))
(def: .public test
Test
(<| (_.covering /._)
(do [! random.monad]
[.let [measurement (# ! each (i.% +1000) random.int)]
m0 measurement
m1 measurement])
(all _.and
(_.coverage [/.inline:]
(i.= (..!quadrance/2 m0 m1)
(..quadrance/2 m0 m1)))
)))
|