diff --git a/src/Vatras/Test/Experiments/ADT-to-TikZ-Forest.agda b/src/Vatras/Test/Experiments/ADT-to-TikZ-Forest.agda new file mode 100644 index 00000000..29d98c99 --- /dev/null +++ b/src/Vatras/Test/Experiments/ADT-to-TikZ-Forest.agda @@ -0,0 +1,66 @@ +open import Vatras.Framework.Definitions +module Vatras.Test.Experiments.ADT-to-TikZ-Forest where + +open import Data.List as List using ([]; _∷_) +open import Data.Product using (_,_; proj₁) +open import Data.String as String using (String; _++_; intersperse) + +open import Size using (∞) +open import Function using (id) + +open import Vatras.Framework.Variants +open import Vatras.Lang.CCC as CCC using (CCC) +open import Vatras.Lang.2CC using (2CC) +open import Vatras.Lang.ADT +open import Vatras.Translation.LanguageMap + +open import Vatras.Test.Experiment +open import Vatras.Show.Lines +open import Vatras.Util.Named + +STR : 𝔸 +STR = (String , String._β‰Ÿ_) + +STRCCC = CCC String ∞ STR +STR2CC = 2CC String ∞ STR +STRADT = ADT (Rose ∞) String STR + +rose-to-tikz-forest : βˆ€ {i} {A : 𝔸} β†’ (atoms A β†’ String) β†’ Rose i A β†’ Lines +rose-to-tikz-forest pretty-atom (a -< [] >-) = > "[" ++ pretty-atom a ++ "]" +rose-to-tikz-forest pretty-atom (a -< cs@(_ ∷ _) >-) = do + > "[" ++ pretty-atom a + indent 2 do + lines (List.map (rose-to-tikz-forest pretty-atom) cs) + > "]" + +adt-to-tikz-forest : βˆ€ {A : 𝔸} β†’ {V : 𝕍} β†’ {F : 𝔽} β†’ (V A β†’ Lines) β†’ (F β†’ String) β†’ ADT V F A β†’ Lines +adt-to-tikz-forest pretty-variant show-F (leaf v) = pretty-variant v +adt-to-tikz-forest pretty-variant show-F (D ⟨ l , r ⟩) = do + > "[" ++ show-F D + indent 2 do + adt-to-tikz-forest pretty-variant show-F l + adt-to-tikz-forest pretty-variant show-F r + > "]" + +CCC-to-ADT : STRCCC β†’ STRADT +CCC-to-ADT ccc = adt + where + open Expressiveness-String + + bcc : STR2CC + bcc = proj₁ (2CC≽CCC ccc) + + adt : STRADT + adt = proj₁ (ADT≽2CC bcc) + +tikz-export-experiment : Experiment STRCCC +getName tikz-export-experiment = "Tikz-Export" +get tikz-export-experiment (ccc called name) = do + [ Center ]> "Input CCC expression:" + linebreak + CCC.pretty id ccc + linebreak + [ Center ]> "Tikz export of corresponding ADT:" + linebreak + let adt = CCC-to-ADT ccc + adt-to-tikz-forest (rose-to-tikz-forest Ξ» a β†’ "$" ++ a ++ "$") id adt