{-# OPTIONS -fcontext-stack=100 #-} {-# LANGUAGE EmptyDataDecls #-} module Test where import Language.Grammars.AspectAG import Data.HList.Label4 import Data.HList.TypeEqGeneric1 import Data.HList.TypeCastGeneric1 --data types------------------------------------------------------------------- data Root = Root Tree deriving Show data Tree = Node Tree Tree | Bin Tree Int Tree | Leaf Int deriving Show --data types' dependent definitions ----non terminals nt_Root = proxy::Proxy Root nt_Tree = proxy::Proxy Tree ----productions data P_Root; p_Root = proxy::Proxy P_Root data P_Node; p_Node = proxy::Proxy P_Node data P_Bin; p_Bin = proxy::Proxy P_Bin data P_Leaf; p_Leaf = proxy::Proxy P_Leaf ----children labels data Ch_tree; ch_tree = proxy::Proxy (Ch_tree, Tree) data Ch_l; ch_l = proxy::Proxy (Ch_l, Tree) data Ch_r; ch_r = proxy::Proxy (Ch_r, Tree) data Ch_i; ch_i = proxy::Proxy (Ch_i, Int) data Ch_lb; ch_lb = proxy::Proxy (Ch_lb, Tree) data Ch_rb; ch_rb = proxy::Proxy (Ch_rb, Tree) data Ch_ib; ch_ib = proxy::Proxy (Ch_ib, Int) ----catamorphism sem_Tree asp (Node left right) = knit (asp # p_Node) ( ch_l .=. sem_Tree asp left .*. ch_r .=. sem_Tree asp right .*. emptyRecord ) sem_Tree asp (Bin left i right) = knit (asp # p_Bin) ( ch_lb .=. sem_Tree asp left .*. ch_ib .=. sem_Lit i .*. ch_rb .=. sem_Tree asp right .*. emptyRecord ) sem_Tree asp (Leaf i ) = knit (asp # p_Leaf) ( ch_i .=. sem_Lit i .*. emptyRecord ) sem_Root asp (Root t ) = knit (asp # p_Root) ( ch_tree .=. sem_Tree asp t .*. emptyRecord ) --repmin----------------------------------------------------------------------- data Att_smin; smin = proxy::Proxy Att_smin data Att_ival; ival = proxy::Proxy Att_ival data Att_sres; sres = proxy::Proxy Att_sres asp_smin () = synAspect smin ( nt_Tree .*. hNil ) (min::Int->Int->Int) (0::Int) ( p_Node .*. p_Bin .*. hNil ) ( p_Leaf .=. (\(Fam _ _ chi _) -> chi # ch_i) .*. emptyRecord ) asp_ival f = inhAspect ival ( nt_Tree .*. hNil ) ( p_Node .*. p_Bin .*. hNil ) ( p_Root .=. (\(Fam _ _ chi _) -> ( ch_tree .=. f (chi # ch_tree) .*. emptyRecord ) ) .*. emptyRecord ) asp_sres () = synAspect sres ( nt_Root .*. nt_Tree .*. hNil ) Node (Leaf 0) ( p_Node .*. hNil ) ( p_Root .=. (\(Fam _ _ chi _) -> (chi # ch_tree) # sres) .*. p_Leaf .=. (\(Fam _ _ _ par) -> Leaf (par # ival)) .*. p_Bin .=. (\(Fam _ _ chi _) -> Bin ((chi # ch_lb) # sres) (chi # ch_ib) ((chi # ch_rb) # sres)) .*. emptyRecord ) asp_repmin () = asp_smin () .+. asp_sres () .+. asp_ival (\c -> c # smin) repmin tree = sem_Root (asp_repmin ()) (Root tree) () # sres --average---------------------------------------------------------------------- data Att_ssum; ssum = proxy::Proxy Att_ssum data Att_scnt; scnt = proxy::Proxy Att_scnt asp_ssum () = synAspect ssum ( nt_Tree .*. hNil ) ((+)::Int->Int->Int) (0::Int) ( p_Node .*. p_Bin .*. hNil ) ( p_Leaf .=. (\(Fam _ _ chi _) -> chi # ch_i) .*. emptyRecord ) asp_scnt () = synAspect scnt ( nt_Tree .*. hNil ) ((+)::Int->Int->Int) (0::Int) ( p_Node .*. p_Bin .*. hNil ) ( p_Leaf .=. (\(Fam _ _ chi _) -> 1) .*. emptyRecord ) asp_avg () = asp_scnt () .+. asp_ssum () .+. asp_sres () .+. asp_ival (\c -> div (c # ssum) (c # scnt)) avg tree = sem_Root (asp_avg ()) (Root tree) () # sres ----example-------------------------------------------------------------------- examplet = (Node (Bin (Node (Leaf 1) (Leaf 4)) 100 (Node (Leaf 2) (Leaf 1)) ) (Node (Bin (Leaf 9) 300 (Leaf 8)) (Leaf 6) ) ) res_repmin = repmin examplet res_avg = avg examplet