diff options
| author | krasimir <krasimir@chalmers.se> | 2008-10-19 16:38:56 +0000 |
|---|---|---|
| committer | krasimir <krasimir@chalmers.se> | 2008-10-19 16:38:56 +0000 |
| commit | 9837fb8fb17be9ecf5d90f3fb5a97ec6389f9eef (patch) | |
| tree | 72f9ac01d47b5ae6e690331040385bcf59ed37c0 /src/PGF | |
| parent | a6c4747b112a3399ee3b7222766c266e4d34fa0a (diff) | |
move PGF.Quiz to GF.Quiz. It is not part of the PGF API
Diffstat (limited to 'src/PGF')
| -rw-r--r-- | src/PGF/Quiz.hs | 71 |
1 files changed, 0 insertions, 71 deletions
diff --git a/src/PGF/Quiz.hs b/src/PGF/Quiz.hs deleted file mode 100644 index 096930f46..000000000 --- a/src/PGF/Quiz.hs +++ /dev/null @@ -1,71 +0,0 @@ ----------------------------------------------------------------------- --- | --- Module : TeachYourself --- Maintainer : AR --- Stability : (stable) --- Portability : (portable) --- --- > CVS $Date: 2005/04/21 16:46:13 $ --- > CVS $Author: bringert $ --- > CVS $Revision: 1.7 $ --- --- translation and morphology quiz. AR 10\/5\/2000 -- 12\/4\/2002 -- 14\/6\/2008 --------------------------------------------------------------------------------- - -module PGF.Quiz ( - mkQuiz, - translationList, - morphologyList - ) where - -import PGF -import PGF.ShowLinearize - -import GF.Data.Operations -import GF.Infra.UseIO -import GF.Text.Coding - -import System.Random - -import Data.List (nub) - --- translation and morphology quiz. AR 10/5/2000 -- 12/4/2002 - --- generic quiz function - -mkQuiz :: String -> String -> [(String,[String])] -> IO () -mkQuiz cod msg tts = do - let qas = [ (q, mkAnswer cod as) | (q,as) <- tts] - teachDialogue qas msg - -translationList :: - PGF -> Language -> Language -> Category -> Int -> IO [(String,[String])] -translationList pgf ig og cat number = do - ts <- generateRandom pgf cat >>= return . take number - return $ map mkOne $ ts - where - mkOne t = (norml (linearize pgf ig t), map (norml . linearize pgf og) (homonyms t)) - homonyms = nub . parse pgf ig cat . linearize pgf ig - -morphologyList :: PGF -> Language -> Category -> Int -> IO [(String,[String])] -morphologyList pgf ig cat number = do - ts <- generateRandom pgf cat >>= return . take (max 1 number) - gen <- newStdGen - let ss = map (tabularLinearize pgf (mkCId ig)) ts - let size = length (head ss) - let forms = take number $ randomRs (0,size-1) gen - return [(head (snd (head pws)) +++ par, ws) | - (pws,i) <- zip ss forms, let (par,ws) = pws !! i] - --- | compare answer to the list of right answers, increase score and give feedback -mkAnswer :: String -> [String] -> String -> (Integer, String) -mkAnswer cod as s = - if (elem (norm s) as) - then (1,"Yes.") - else (0,"No, not" +++ s ++ ", but" ++++ enc (unlines as)) - where - norm = unwords . words . decodeUnicode cod - enc = encodeUnicode cod - -norml = unwords . words - |
