summaryrefslogtreecommitdiff
path: root/src/GF/UseGrammar/Generate.hs
diff options
context:
space:
mode:
authoraarne <unknown>2005-03-03 15:40:51 +0000
committeraarne <unknown>2005-03-03 15:40:51 +0000
commit198ac61a65f78ae45dc4d523b75a6d2cd2a2b7fc (patch)
treed67683cff22553944a9a1e7709e3e0417ee80ef2 /src/GF/UseGrammar/Generate.hs
parentf07ea93082ecf3d2fa1c54de8ec1b244d7988233 (diff)
better gt all the way
Diffstat (limited to 'src/GF/UseGrammar/Generate.hs')
-rw-r--r--src/GF/UseGrammar/Generate.hs42
1 files changed, 15 insertions, 27 deletions
diff --git a/src/GF/UseGrammar/Generate.hs b/src/GF/UseGrammar/Generate.hs
index d19b42f2f..95440dae2 100644
--- a/src/GF/UseGrammar/Generate.hs
+++ b/src/GF/UseGrammar/Generate.hs
@@ -5,9 +5,9 @@
-- Stability : (stable)
-- Portability : (portable)
--
--- > CVS $Date: 2005/03/03 16:10:37 $
+-- > CVS $Date: 2005/03/03 16:40:51 $
-- > CVS $Author: aarne $
--- > CVS $Revision: 1.10 $
+-- > CVS $Revision: 1.11 $
--
-- Generate all trees of given category and depth. AR 30\/4\/2004
--
@@ -86,14 +86,21 @@ tr2str (Tr (N (_,at,val,_,_),ts)) = case (at,val) of
-- If a tree is given as argument, generation concerns its metavariables.
generate :: SGrammar -> Bool -> SCat -> Int -> Maybe Int -> Maybe STree -> [STree]
-generate gr ifm cat i _ Nothing = errVal [] $ lookupTree id cat $ genAll i
+generate gr ifm cat i mn mt = case mt of
+ Nothing -> gen cat
+ Just t -> genM t
where
+
+ gen cat = errVal [] $ lookupTree id cat $ allTrees
+
+ allTrees = genAll i
+
-- lazy bottom-up dynamic generation
genAll :: Int -> BinTree (SCat,[STree])
genAll i = iter i genNext (mapTree (\ (c,_) -> (c,[])) gr)
iter 0 f tr = tr
- iter n f tr = f (iter (n-1) f tr)
+ iter n f tr = iter (n-1) f (f tr)
genNext tr = mapTree (genNew tr) tr
@@ -107,30 +114,11 @@ generate gr ifm cat i _ Nothing = errVal [] $ lookupTree id cat $ genAll i
where
look c = errVal [] $ lookupTree id c tr
- funs cat = errVal [] $ lookupTree id cat gr
-
-generate gr ifm cat i mn mt = case mt of
- Nothing -> [t | (c,t) <- gen i [], c == cat]
-
- Just t -> genM i t
-
- where
-
- gen :: Int -> [(SCat,STree)] -> [(SCat,STree)]
- gen n cts = if n==0 then cts else
- gen (n-1) ([(c,SApp (f, xs)) | (f,(cs,c)) <- allRules gr, xs <- args cs cts] ++ cts)
-
- args :: [SCat] -> [(SCat,STree)] -> [[STree]]
- args cs cts = combinations
- [constr (ifmetas c [t | (k,t) <- cts, k == c]) | c <- cs]
-
- constr = maybe id take mn
-
- ifmetas c = if ifm then (SMeta c :) else id
+ funs cat = maybe id take mn $ errVal [] $ lookupTree id cat gr
- genM n t = case t of
- SApp (f,ts) -> [SApp (f,ts') | ts' <- combinations (map (genM (n-1)) ts)]
- SMeta k -> [t | (c,t) <- gen n [], c == k]
+ genM t = case t of
+ SApp (f,ts) -> [SApp (f,ts') | ts' <- combinations (map genM ts)]
+ SMeta k -> gen k
_ -> [t]
type SGrammar = BinTree (SCat,[SRule])