diff options
| author | Inari Listenmaa <inari.listenmaa@gmail.com> | 2018-04-06 16:32:58 +0200 |
|---|---|---|
| committer | Inari Listenmaa <inari.listenmaa@gmail.com> | 2018-04-06 16:32:58 +0200 |
| commit | b9d0012f6b957446fdf82509469e2fbbe260285a (patch) | |
| tree | 1ec49daf3e2a45399d76423155662277b711a371 /src/tools/gftest/EqRel.hs | |
| parent | 99db3945c16fe3ad1063aa48e0cfb97229029172 (diff) | |
Add a tool to generate test cases for GF grammars
Diffstat (limited to 'src/tools/gftest/EqRel.hs')
| -rw-r--r-- | src/tools/gftest/EqRel.hs | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/src/tools/gftest/EqRel.hs b/src/tools/gftest/EqRel.hs new file mode 100644 index 000000000..823900ae0 --- /dev/null +++ b/src/tools/gftest/EqRel.hs @@ -0,0 +1,32 @@ +module EqRel where + +import qualified Data.Map as M +import Data.List ( sort ) + +data EqRel a = Top | Classes [[a]] deriving (Eq,Ord,Show) + +(/\) :: (Ord a) => EqRel a -> EqRel a -> EqRel a +Top /\ r = r +r /\ Top = r +Classes xss /\ Classes yss = Classes $ sort $ map sort $ concat -- maybe throw away singleton lists? + [ M.elems tabXs + | xs <- xss + , let tabXs = M.fromListWith (++) + [ (tabYs M.! x, [x]) + | x <- xs ] + ] + + where + tabYs = M.fromList [ (y,representative) + | ys <- yss + , let representative = head ys + , y <- ys ] + +basic :: (Ord a) => [a] -> EqRel Int +basic xs = Classes $ sort $ map sort $ M.elems $ M.fromListWith (++) + [ (x,[i]) | (x,i) <- zip xs [0..] ] + +rep :: EqRel Int -> Int -> Int +rep Top j = 0 +rep (Classes xss) j = head [ head xs | xs <- xss, j `elem` xs ] + |
