我不知道它回答你的問題,但這裏是我將如何實現基本的TreeForm:
decompose[expr_?AtomQ] := expr
decompose[expr_] := Block[{lev = Level[expr, {1}]},
Sow[Thread[expr -> lev]]; decompose /@ lev;]
treeForm[expr_] := Reap[decompose[expr]][[-1, 1]] // Flatten
然後:
編輯 ÿ如果你是對的,這不是一棵樹。爲了使它成爲一棵樹,每個表達都應該帶着它的位置。有點像這樣:
ClearAll[treePlot, node, decompose2];
SetAttributes[{treePlot, node, decompose2}, HoldAll];
decompose2[expr_] /; AtomQ[Unevaluated[expr]] := node[expr];
decompose2[expr_] := Module[{pos, list},
pos = SortBy[
Position[Unevaluated[expr], _, {0, Infinity}, Heads -> False],
Length];
list = Extract[Unevaluated[expr], pos, node];
list = MapThread[Append, {list, pos}];
ReplaceList[
list, {___, node[e1_, p1_], ___, node[e2_, p2_], ___} /;
Length[p2] == Length[p1] + 1 &&
Most[p2] == p1 :> (node[e1, p1] -> node[e2, p2])]
]
然後
treePlot2[expr_] :=
Module[{data = decompose2[a^2 + Subscript[b, 2] + 3 c], gr, vlbls},
gr = Graph[data];
vlbls = Table[vl -> (HoldForm @@ {vl[[1]]}), {vl, VertexList[gr]}];
Graph[data, VertexLabels -> vlbls, ImagePadding -> 50]
]
的hackish的方式,但它是那種簡單的解決方案,我希望的。我分解的對象被存儲爲字符串,所以非常適合(無意外評估)。 – Szabolcs 2011-04-13 23:37:01
你能否建議一種與此解決方案兼容的方式來更改節點的字體? (需要顯示默認字體中不存在的字形) – Szabolcs 2011-05-05 10:36:36
@Szabolcs您可以使用'TreeForm'的'VertexRenderingFunction'選項來完全控制節點的外觀, 'VertexRenderingFunction - >(Inset [Framed [Style [#2,FontFamily - >「Webdings」],Background-> LightYellow],#1]&)'。 – WReach 2011-05-05 14:32:57