Free cookie consent management tool by TermsFeed Policy Generator

source: branches/HeuristicLab.EvolutionTracking/HeuristicLab.Encodings.SymbolicExpressionTreeEncoding/3.4/Formatters/SymbolicExpressionTreeLatexFormatter.cs @ 10456

Last change on this file since 10456 was 10456, checked in by bburlacu, 10 years ago

#1772: Merged trunk changes.

File size: 3.6 KB
Line 
1using System;
2using System.Collections.Generic;
3using System.Globalization;
4using System.Linq;
5using System.Text;
6using HeuristicLab.Common;
7using HeuristicLab.Core;
8
9namespace HeuristicLab.Encodings.SymbolicExpressionTreeEncoding {
10  [Item("LaTeX/PDF Formatter", "Formatter for symbolic expression trees for use with latex.")]
11  public class SymbolicExpressionTreeLatexFormatter : NamedItem, ISymbolicExpressionTreeStringFormatter {
12    private readonly static Dictionary<string, string> SymbolNamesMap = new Dictionary<string, string>
13    {
14      {"ProgramRootSymbol", "Prog"},
15      {"StartSymbol","RPB"},
16      {"Addition", "$+$"},
17      {"Subtraction", "$-$"},
18      {"Multiplication", "$\\times$"},
19      {"Division", "$\\div$"}
20    };
21    private readonly ReingoldTilfordLayoutEngine<ISymbolicExpressionTreeNode> layoutEngine;
22    private readonly SymbolicExpressionTreeLayoutAdapter layoutAdapter;
23
24    public SymbolicExpressionTreeLatexFormatter() {
25      layoutEngine = new ReingoldTilfordLayoutEngine<ISymbolicExpressionTreeNode>();
26      layoutAdapter = new SymbolicExpressionTreeLayoutAdapter();
27    }
28
29    protected SymbolicExpressionTreeLatexFormatter(SymbolicExpressionTreeLatexFormatter original, Cloner cloner)
30      : base(original, cloner) {
31      layoutEngine = new ReingoldTilfordLayoutEngine<ISymbolicExpressionTreeNode>();
32      layoutAdapter = new SymbolicExpressionTreeLayoutAdapter();
33    }
34
35    public override IDeepCloneable Clone(Cloner cloner) {
36      return new SymbolicExpressionTreeLatexFormatter(this, cloner);
37    }
38
39    public string Format(ISymbolicExpressionTree symbolicExpressionTree) {
40      var layoutNodes = layoutAdapter.Convert(symbolicExpressionTree).ToList();
41      layoutEngine.Reset();
42      layoutEngine.Root = layoutNodes[0];
43      foreach (var ln in layoutNodes)
44        layoutEngine.AddNode(ln.Content, ln);
45      layoutEngine.CalculateLayout();
46      var nodeCoordinates = layoutEngine.GetNodeCoordinates();
47      var sb = new StringBuilder();
48      var nl = Environment.NewLine;
49      sb.Append("\\documentclass[class=minimal,border=0pt]{standalone}" + nl +
50                "\\usepackage{tikz}" + nl +
51                "\\begin{document}" + nl +
52                "\\begin{tikzpicture}" + nl +
53                "\\def\\ws{1}" + nl +
54                "\\def\\hs{0.7}" + nl);
55
56      const double ws = 1.0, hs = 0.7; // some scaling factors useful for fine-tuning document appearance before latex compilation
57      var nodes = symbolicExpressionTree.IterateNodesBreadth().ToList();
58      var nodeIndices = new Dictionary<ISymbolicExpressionTreeNode, int>();
59      for (int i = 0; i < nodes.Count; ++i) {
60        var node = nodes[i];
61        nodeIndices.Add(node, i);
62        var symbolName = node.Symbol.Name;
63        var nodeName = SymbolNamesMap.ContainsKey(symbolName) ? SymbolNamesMap[symbolName] : symbolName;
64        var coord = nodeCoordinates[node];
65
66        sb.AppendLine(string.Format(CultureInfo.InvariantCulture, "\\node ({0}) at (\\ws*{1},\\hs*{2}) {{{3}}};", i, ws * coord.X, -hs * coord.Y, EscapeLatexString(nodeName)));
67      }
68
69      for (int i = 0; i < nodes.Count; ++i) {
70        foreach (var s in nodes[i].Subtrees) {
71          sb.AppendLine(string.Format(CultureInfo.InvariantCulture, "\\draw ({0}) -- ({1});", i, nodeIndices[s]));
72        }
73      }
74
75      sb.AppendLine("\\end{tikzpicture}" + nl + "\\end{document}" + nl);
76
77      return sb.ToString();
78    }
79
80    private static string EscapeLatexString(string s) {
81      return s.Replace("\\", "\\\\").Replace("{", "\\{").Replace("}", "\\}").Replace("_", "\\_");
82    }
83  }
84}
Note: See TracBrowser for help on using the repository browser.