preliminary version of morpho analysis

This commit is contained in:
aarne
2008-06-10 16:00:42 +00:00
parent 613d775a54
commit 59aff851a7
3 changed files with 78 additions and 3 deletions

46
src-3.0/PGF/Morphology.hs Normal file
View File

@@ -0,0 +1,46 @@
module PGF.Morphology where
import PGF.ShowLinearize
import PGF.Data
import PGF.CId
import qualified Data.Map as Map
import Data.List (intersperse)
-- these 4 definitions depend on the datastructure used
type Morpho = Map.Map String [(Lemma,Analysis)]
lookupMorpho :: Morpho -> String -> [(Lemma,Analysis)]
lookupMorpho mo s = maybe noAnalysis id $ Map.lookup s mo
buildMorpho :: PGF -> CId -> Morpho
buildMorpho pgf = Map.fromListWith (++) . collectWords pgf
prFullFormLexicon :: Morpho -> String
prFullFormLexicon mo =
unlines [w ++ " : " ++ prMorphoAnalysis ts | (w,ts) <- Map.assocs mo]
prMorphoAnalysis :: [(Lemma,Analysis)] -> String
prMorphoAnalysis lps = unlines [l ++ " " ++ p | (l,p) <- lps]
type Lemma = String
type Analysis = String
noAnalysis :: [(Lemma,Analysis)]
noAnalysis = []
collectWords :: PGF -> CId -> [(String, [(Lemma,Analysis)])]
collectWords pgf lang =
concatMap collOne
[(f,c,0) | (f,(DTyp [] c _,_)) <- Map.toList $ funs $ abstract pgf]
where
collOne (f,c,i) =
fromRec f [prCId c] (recLinearize pgf lang (EApp f (replicate i (EMeta 888))))
fromRec f v r = case r of
RR rs -> concat [fromRec f v t | (_,t) <- rs]
RT rs -> concat [fromRec f (p:v) t | (p,t) <- rs]
RFV rs -> concatMap (fromRec f v) rs
RS s -> [(s,[(prCId f,unwords (reverse v))])]
RCon c -> [] ---- inherent

View File

@@ -1,4 +1,5 @@
module PGF.ShowLinearize (
Record (..), recLinearize, --- used in PGF.Morphology
tableLinearize,
recordLinearize,
termLinearize,