mirror of
https://github.com/maciej-bendkowski/generic-boltzmann-brain.git
synced 2024-11-22 10:51:19 +03:00
MotzkinTree
sampler tests
This commit is contained in:
parent
e152eb2b73
commit
f8672b62e5
@ -95,6 +95,7 @@ test-suite generic-boltzmann-brain-test
|
|||||||
Test.Sampler
|
Test.Sampler
|
||||||
Test.Samplers.BinTree
|
Test.Samplers.BinTree
|
||||||
Test.Samplers.Lambda
|
Test.Samplers.Lambda
|
||||||
|
Test.Samplers.MotzkinTree
|
||||||
Test.Samplers.Tree
|
Test.Samplers.Tree
|
||||||
Test.Utils
|
Test.Utils
|
||||||
Paths_generic_boltzmann_brain
|
Paths_generic_boltzmann_brain
|
||||||
|
@ -10,6 +10,7 @@ import Data.Boltzmann (
|
|||||||
|
|
||||||
import Test.Samplers.BinTree (BinTree)
|
import Test.Samplers.BinTree (BinTree)
|
||||||
import Test.Samplers.Lambda (BinLambda, Lambda, abstractions)
|
import Test.Samplers.Lambda (BinLambda, Lambda, abstractions)
|
||||||
|
import Test.Samplers.MotzkinTree (MotzkinTree)
|
||||||
import Test.Samplers.Tree (Tree, Tree')
|
import Test.Samplers.Tree (Tree, Tree')
|
||||||
|
|
||||||
import System.Random.SplitMix (SMGen)
|
import System.Random.SplitMix (SMGen)
|
||||||
@ -31,6 +32,10 @@ tests =
|
|||||||
\binTree ->
|
\binTree ->
|
||||||
let s = size @BinTree binTree
|
let s = size @BinTree binTree
|
||||||
in 800 <= s && s <= 1200
|
in 800 <= s && s <= 1200
|
||||||
|
, QC.testProperty "MotzkinTree sampler respects size constraints" $
|
||||||
|
\tree ->
|
||||||
|
let s = size @MotzkinTree tree
|
||||||
|
in 800 <= s && s <= 1200
|
||||||
, QC.testProperty "Tree sampler respects size constraints" $
|
, QC.testProperty "Tree sampler respects size constraints" $
|
||||||
\tree ->
|
\tree ->
|
||||||
let s = size @Tree tree
|
let s = size @Tree tree
|
||||||
|
44
test/Test/Samplers/MotzkinTree.hs
Normal file
44
test/Test/Samplers/MotzkinTree.hs
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
{-# LANGUAGE DeriveGeneric #-}
|
||||||
|
{-# LANGUAGE TemplateHaskell #-}
|
||||||
|
|
||||||
|
module Test.Samplers.MotzkinTree (MotzkinTree (..)) where
|
||||||
|
|
||||||
|
import Data.Boltzmann (
|
||||||
|
BoltzmannSampler (..),
|
||||||
|
LowerBound (MkLowerBound),
|
||||||
|
System (..),
|
||||||
|
UpperBound (MkUpperBound),
|
||||||
|
mkBoltzmannSampler,
|
||||||
|
mkDefWeights,
|
||||||
|
quickCheckRejectionSampler,
|
||||||
|
)
|
||||||
|
import Data.Default (def)
|
||||||
|
import GHC.Generics (Generic)
|
||||||
|
import Test.QuickCheck (Arbitrary (arbitrary, shrink))
|
||||||
|
import Test.Utils (Size (size))
|
||||||
|
|
||||||
|
data MotzkinTree
|
||||||
|
= Leaf
|
||||||
|
| UnaryNode MotzkinTree
|
||||||
|
| BinNode MotzkinTree MotzkinTree
|
||||||
|
deriving (Generic, Show)
|
||||||
|
|
||||||
|
instance Size MotzkinTree where
|
||||||
|
size = \case
|
||||||
|
Leaf -> 1
|
||||||
|
UnaryNode t -> 1 + size t
|
||||||
|
BinNode lt rt -> 1 + size lt + size rt
|
||||||
|
|
||||||
|
mkBoltzmannSampler
|
||||||
|
System
|
||||||
|
{ targetType = ''MotzkinTree
|
||||||
|
, meanSize = 1000
|
||||||
|
, frequencies = def
|
||||||
|
, weights = $(mkDefWeights ''MotzkinTree)
|
||||||
|
}
|
||||||
|
|
||||||
|
instance Arbitrary MotzkinTree where
|
||||||
|
arbitrary =
|
||||||
|
quickCheckRejectionSampler $
|
||||||
|
const (MkLowerBound 800, MkUpperBound 1200)
|
||||||
|
shrink = const []
|
Loading…
Reference in New Issue
Block a user