Compare commits
	
		
			No commits in common. "1b4656a09912f718289a6d5d9ee1d68b5d94f922" and "d378cc45259379f3f51d8ccd5a1df8a5699a70ce" have entirely different histories.
		
	
	
		
			1b4656a099
			...
			d378cc4525
		
	
		
| @ -73,7 +73,7 @@ mapTree = fmap | |||||||
| valueAt :: Path -> Tree a -> Maybe a | valueAt :: Path -> Tree a -> Maybe a | ||||||
| valueAt _ End = Nothing | valueAt _ End = Nothing | ||||||
| valueAt [] (Node a _ _) = Just a | valueAt [] (Node a _ _) = Just a | ||||||
| valueAt (x:xs) (Node _ l r) = valueAt xs $ if x == L then l else r | valueAt (x:xs) (Node a l r) = valueAt xs $ if x == L then l else r | ||||||
| 
 | 
 | ||||||
| -- | Find a path to a node that contains the given value. | -- | Find a path to a node that contains the given value. | ||||||
| -- | -- | ||||||
| @ -94,10 +94,10 @@ valueAt (x:xs) (Node _ l r) = valueAt xs $ if x == L then l else r | |||||||
| -- | -- | ||||||
| 
 | 
 | ||||||
| pathTo :: Eq a => a -> Tree a -> Maybe Path | pathTo :: Eq a => a -> Tree a -> Maybe Path | ||||||
| pathTo _ End = Nothing | pathTo v End = Nothing | ||||||
| pathTo v (Node a l r) = orElse currentNode $ orElse (pathHelper v l L) $ pathHelper v r R | pathTo v (Node a l r) = orElse currentNode $ orElse (pathHelper v l L) $ pathHelper v r R | ||||||
|     where |     where | ||||||
|         currentNode = if a == v then Just [] else Nothing |         currentNode = if a == v then Just [] else Nothing | ||||||
|         pathHelper _ tree dir = fmap (dir:) (pathTo v tree) |         pathHelper v tree dir = fmap (dir:) (pathTo v tree) | ||||||
|         orElse m1 m2 = if isJust m1 then m1 else m2 |         orElse m1 m2 = if isJust m1 then m1 else m2 | ||||||
|         isJust mx = mx /= Nothing |         isJust mx = mx /= Nothing | ||||||
|  | |||||||
							
								
								
									
										102
									
								
								HW3.fedorind.hs
									
									
									
									
									
								
							
							
						
						
									
										102
									
								
								HW3.fedorind.hs
									
									
									
									
									
								
							| @ -1,102 +0,0 @@ | |||||||
| -- Author: Danila Fedorin |  | ||||||
| import Data.List |  | ||||||
| 
 |  | ||||||
| -- Definitions |  | ||||||
| type Var = String |  | ||||||
| type Macro = String |  | ||||||
| 
 |  | ||||||
| data PenMode = Up | Down |  | ||||||
| 
 |  | ||||||
| data Expr = Variable Var |  | ||||||
|           | Number Int |  | ||||||
|           | Sum Expr Expr |  | ||||||
| 
 |  | ||||||
| data Cmd = Pen PenMode |  | ||||||
|          | Move Expr Expr |  | ||||||
|          | Define Macro [Var] Prog |  | ||||||
|          | Call Macro [Expr] |  | ||||||
| 
 |  | ||||||
| type Prog = [Cmd] |  | ||||||
| 
 |  | ||||||
| -- HW Code |  | ||||||
| -- define line(x1, y1, x2, y2) { |  | ||||||
| --     pen up; move (x1, y1); |  | ||||||
| --     pen down; move(x2, y2); |  | ||||||
| -- } |  | ||||||
| lineMacro = Define "line" [ "x1", "y1", "x2", "y2" ] |  | ||||||
|     [ Pen Up |  | ||||||
|     , Move (Variable "x1") (Variable "y1") |  | ||||||
|     , Pen Down |  | ||||||
|     , Move (Variable "x2") (Variable "y2") |  | ||||||
|     ] |  | ||||||
| 
 |  | ||||||
| -- define nix(x, y, w, h) { |  | ||||||
| --     call line(x, y, x + w, y + h); |  | ||||||
| --     call line(x + w, y, x, y + h); |  | ||||||
| -- } |  | ||||||
| nixMacro = Define "nix" [ "x", "y", "w", "h" ] |  | ||||||
|     [ Call "line" |  | ||||||
|         [ Variable "x" |  | ||||||
|         , Variable "y" |  | ||||||
|         , Sum (Variable "x") (Variable "w") |  | ||||||
|         , Sum (Variable "y") (Variable "h") |  | ||||||
|         ] |  | ||||||
|     , Call "line" |  | ||||||
|         [ Sum (Variable "x") (Variable "w") |  | ||||||
|         , Variable "y" |  | ||||||
|         , Variable "x" |  | ||||||
|         , Sum (Variable "y") (Variable "h") |  | ||||||
|         ] |  | ||||||
|     ] |  | ||||||
| 
 |  | ||||||
| steps :: Int -> Prog |  | ||||||
| steps n = base ++ stepList |  | ||||||
|     where |  | ||||||
|         base = [ Pen Up, Move (Number 0) (Number 0), Pen Down ] |  | ||||||
|         stepList = [1..n] >>= (\i -> [ Move (Number (i -1)) (Number i), Move (Number i) (Number i) ]) |  | ||||||
| 
 |  | ||||||
| prettyPrintExpr :: Expr -> String |  | ||||||
| prettyPrintExpr (Variable v) = v |  | ||||||
| prettyPrintExpr (Number i) = show i |  | ||||||
| prettyPrintExpr (Sum l r) = prettyPrintExpr l ++ "+" ++ prettyPrintExpr r |  | ||||||
| 
 |  | ||||||
| prettyPrintPenMode :: PenMode -> String |  | ||||||
| prettyPrintPenMode Up = "up" |  | ||||||
| prettyPrintPenMode Down = "down" |  | ||||||
| 
 |  | ||||||
| prettyPrintCmd :: Cmd -> [String] |  | ||||||
| prettyPrintCmd (Pen m) = [ "pen " ++ prettyPrintPenMode m ++ ";" ] |  | ||||||
| prettyPrintCmd (Move l r) = [ "move(" ++ prettyPrintExpr l ++ ", " ++ prettyPrintExpr r ++ ");" ] |  | ||||||
| prettyPrintCmd (Define m vs cmds) = ("define " ++ m ++ "(" ++ intercalate ", " vs ++ ") {") : map ("    " ++) (cmds >>= prettyPrintCmd) ++ [ "}" ] |  | ||||||
| prettyPrintCmd (Call n xs) = [ "call " ++ n ++ "(" ++ intercalate ", " (map prettyPrintExpr xs) ++ ");" ] |  | ||||||
| 
 |  | ||||||
| prettyPrint :: Prog -> String |  | ||||||
| prettyPrint prog = intercalate "\n" $ (prog >>= prettyPrintCmd) ++ [ "" ] |  | ||||||
| 
 |  | ||||||
| macros :: Prog -> [Macro] |  | ||||||
| macros xs = xs >>= macrosC |  | ||||||
|     where |  | ||||||
|         macrosC (Define n vs cs) = n:(cs >>= macrosC) |  | ||||||
|         macrosC _ = [] |  | ||||||
| 
 |  | ||||||
| sortWith :: Ord b => (a -> b) -> [a] -> [a] |  | ||||||
| sortWith f = sortBy (\l r -> compare (f l) (f r)) |  | ||||||
| 
 |  | ||||||
| optE :: Expr -> Expr |  | ||||||
| optE expr = mergeAll $ sortWith exprOrdinal $ listTerms expr |  | ||||||
|     where |  | ||||||
|         listTerms (Sum l r) = listTerms l ++ listTerms r |  | ||||||
|         listTerms e = [ e ] |  | ||||||
|         exprOrdinal (Number _) = 2 |  | ||||||
|         exprOrdinal _ = 1 |  | ||||||
|         mergeTwo (Number i1) (Number i2) = Number (i1 + i2) |  | ||||||
|         mergeTwo l r = Sum l r |  | ||||||
|         mergeAll [x] = x |  | ||||||
|         mergeAll xs = foldr1 mergeTwo xs |  | ||||||
| 
 |  | ||||||
| optP :: Prog -> Prog |  | ||||||
| optP = map optC |  | ||||||
|     where |  | ||||||
|         optC (Move e1 e2) = Move (optE e1) (optE e2) |  | ||||||
|         optC (Call n exs) = Call n (map optE exs) |  | ||||||
|         optC c = c |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user