diff options
| author | peb <unknown> | 2005-04-16 04:40:48 +0000 |
|---|---|---|
| committer | peb <unknown> | 2005-04-16 04:40:48 +0000 |
| commit | 9e510f5245ac8ee1a7524fbbf49447daaef846d3 (patch) | |
| tree | 1a4f923fa1a4247146d7d0b4caf56021fc0f70a6 /src/GF/Conversion/MCFGtoCFG.hs | |
| parent | 9d112935dc072c399ae86be4fa9cc273b479928e (diff) | |
"Committed_by_peb"
Diffstat (limited to 'src/GF/Conversion/MCFGtoCFG.hs')
| -rw-r--r-- | src/GF/Conversion/MCFGtoCFG.hs | 32 |
1 files changed, 28 insertions, 4 deletions
diff --git a/src/GF/Conversion/MCFGtoCFG.hs b/src/GF/Conversion/MCFGtoCFG.hs index 2b86b633a..236a90aca 100644 --- a/src/GF/Conversion/MCFGtoCFG.hs +++ b/src/GF/Conversion/MCFGtoCFG.hs @@ -4,16 +4,16 @@ -- Stability : (stable) -- Portability : (portable) -- --- > CVS $Date: 2005/04/12 10:49:44 $ +-- > CVS $Date: 2005/04/16 05:40:49 $ -- > CVS $Author: peb $ --- > CVS $Revision: 1.2 $ +-- > CVS $Revision: 1.3 $ -- -- Converting MCFG grammars to (possibly overgenerating) CFG ----------------------------------------------------------------------------- module GF.Conversion.MCFGtoCFG - (convertGrammar) where + (convertGrammar, convertNEGrammar) where import GF.System.Tracing import GF.Infra.Print @@ -25,9 +25,12 @@ import GF.Formalism.MCFG import GF.Formalism.CFG import GF.Conversion.Types +---------------------------------------------------------------------- +-- * converting (possibly erasing) MCFG grammars + convertGrammar :: MGrammar -> CGrammar convertGrammar gram = tracePrt "#context-free rules" (prt.length) $ - concatMap convertRule gram + concatMap convertRule gram convertRule :: MRule -> [CRule] convertRule (Rule (Abs cat args (Name fun mprofile)) (Cnc _ _ record)) @@ -45,6 +48,27 @@ argPlaces :: [Symbol (cat, lbl, Int) tok] -> Int -> [Int] argPlaces lin nr = [ place | (nr', place) <- zip linArgs [0..], nr == nr' ] where linArgs = [ nr' | (_, _, nr') <- filterCats lin ] +---------------------------------------------------------------------- +-- * converting nonerasing MCFG grammars + +convertNEGrammar :: NGrammar -> CGrammar +convertNEGrammar gram = tracePrt "#context-free rules" (prt.length) $ + concatMap convertNERule gram + +convertNERule :: NRule -> [CRule] +convertNERule (Rule (Abs ncat args (Name fun mprofile)) (Cnc _ _ record)) + = [ CFRule (CCat (ncat2mcat ncat) lbl) rhs (Name fun profile) | + Lin lbl lin <- record, + let rhs = map (mapSymbol convertNEArg id) lin, + let cprofile = map (Unify . argPlaces lin) [0 .. length args-1], + let profile = mprofile `composeProfiles` cprofile + ] + +convertNEArg :: (NCat, NLabel, Int) -> CCat +convertNEArg (ncat, lbl, _) = CCat (ncat2mcat ncat) lbl + +---------------------------------------------------------------------- + |
