This document defines types and functions for representing and evaluating algorithms and programs. It includes:
- Types for representing algorithms as lists of substitutions, program configurations, and commands.
- Functions for tasks like finding prefixes, splitting strings, substituting patterns, and evaluating algorithms and programs.
- Examples of algorithms for operations like clearing the first character, adding to the end, and reversing a string.
- Examples of programs for mathematical functions like finding the maximum value and not, addition, and subtraction.
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as TXT, PDF, TXT or read online on Scribd
0 ratings0% found this document useful (0 votes)
359 views3 pages
Haskell 03
This document defines types and functions for representing and evaluating algorithms and programs. It includes:
- Types for representing algorithms as lists of substitutions, program configurations, and commands.
- Functions for tasks like finding prefixes, splitting strings, substituting patterns, and evaluating algorithms and programs.
- Examples of algorithms for operations like clearing the first character, adding to the end, and reversing a string.
- Examples of programs for mathematical functions like finding the maximum value and not, addition, and subtraction.
-- Task 2 ------------------------------------ crop2Parts :: String -> Int -> (String, String) crop2Parts [] _ = ([],[]) crop2Parts xs ind = (take ind xs, drop ind xs)
substitute :: Substitution -> Int -> String -> String
substitute (ls, rs, _) i w = let (fi, se) = crop2Parts w i replaceIfMatch :: String -> String -> String -> String replaceIfMatch str l r | isPrefix l str = r ++ (drop (length l) str) | otherwise = str in fi ++ (replaceIfMatch se ls rs) --if we avoid situations where pattern doesn't match at this index: --substitute (ls, rs, _) i w = take i w ++ rs ++ drop (i + length ls) w
-- Task 3------------------------------------ findPosition :: String -> Substitution -> [(Substitution, Int)] findPosition str (ls, rs, e) = [((ls,rs,e),x) | x <- [0..(length str)], isPrefix ls (drop x str)]
-- Task 5 ------------------------------------ stepA :: Algorithm -> ConfigA -> ConfigA stepA _ (False, st, word) = (False, st, word) stepA algo (_, st, word) = let ((ls,rs,e), i) = head (findAll algo word) in (not e, st + 1, substitute (ls, rs, e) i word)
-- Task 6 ------------------------------------ evalA :: Algorithm -> Int -> String -> Maybe String evalA algo m word = let (rb, rn, rw) = until cond step (True, 0, word) where step :: ConfigA -> ConfigA step (b, n, w) = stepA algo (b, n, w) cond :: ConfigA -> Bool cond (bc, nc, _) = (nc >= m || bc == False) in if ((rn >= m) && (rb == True)) then Nothing else Just rw
-- Task 7 ------------------------------------ maximReg :: Program -> Int maximReg [] = 0 maximReg (x:xs) = max (findMaxReg x 0) (maximReg xs) where findMaxReg :: Command -> Int -> Int findMaxReg (Z a) curr = max a curr findMaxReg (S a) curr = max a curr findMaxReg (T a b) curr = max (max a b) curr findMaxReg (J a b _) curr = maximum (a:(b:[curr])) -- Task 8 ------------------------------------ ini :: Program -> [Int] -> [Int] ini [] _ = error "The program is empty" ini prog xs = let maxlen = maximReg prog in if (maxlen >= (length xs)) then xs ++ (take ((maxlen) - (length xs))[0,0..]) else xs
upd :: [Int] -> Int -> Int-> [Int]
upd [] _ _ = [] upd regs r v = (take r regs) ++ v:(drop (r+1) regs)
-- Task 9 ------------------------------------ stepC :: Program -> ConfigC -> ConfigC stepC progs (nm, st, reg) = let applyCommand :: Command -> ConfigC -> ConfigC applyCommand (Z a) (nma, sta, rega) = (nma+1, sta+1, upd rega (a-1) 0) applyCommand (S a) (nma, sta, rega) = (nma+1, sta+1, upd rega (a-1) ((rega!!(a-1))+1)) applyCommand (T a b) (nma, sta, rega) = (nma+1, sta+1, upd rega (b-1) (reg!!(a-1))) applyCommand (J a b q) (nma, sta, rega) = if (rega!!(a-1)) == (rega!!(b-1)) then (q, sta+1, rega) else (nma+1,sta+1,rega) in applyCommand (progs!!(nm-1)) (nm, st, reg)
-- Task 10 ------------------------------------ evalC :: Program -> Int -> [Int] -> Maybe Int evalC [] _ _ = Nothing evalC prog maxn inireg = let (nm, st, reg) = until cond step (1, 0, (ini prog inireg)) where cond :: ConfigC -> Bool cond (n, s, _) = (s >= maxn || n > (length prog)) step :: ConfigC -> ConfigC step c = stepC prog c in if (nm <= (length prog) && (st >= maxn)) then Nothing else Just (head reg)
---------------------Testing data - Markov normal algorithms
--------------------------- clearBeginOne, addEnd, reverse, multiply:: Algorithm -- deletes first symbol of input word (alphabet {a,b}) clearBeginOne = [ ("ca", "", True) , ("cb", "", True) , ("", "c", False) ]
-- adds "abb" to the end of the input word (alphabet {a,b})