summaryrefslogtreecommitdiff
path: root/src/PGF
diff options
context:
space:
mode:
authorkrasimir <krasimir@chalmers.se>2008-10-19 16:38:56 +0000
committerkrasimir <krasimir@chalmers.se>2008-10-19 16:38:56 +0000
commit9837fb8fb17be9ecf5d90f3fb5a97ec6389f9eef (patch)
tree72f9ac01d47b5ae6e690331040385bcf59ed37c0 /src/PGF
parenta6c4747b112a3399ee3b7222766c266e4d34fa0a (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.hs71
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
-