Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
G
graph_drawing
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Taddeüs Kroes
graph_drawing
Commits
c123d2c4
Commit
c123d2c4
authored
Nov 24, 2011
by
Sander Mathijs van Veen
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added 'function' writing to graph-to-line writer.
parent
37ecd10b
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
51 additions
and
26 deletions
+51
-26
line.py
line.py
+49
-25
node.py
node.py
+2
-1
No files found.
line.py
View file @
c123d2c4
...
@@ -4,30 +4,49 @@ def generate_line(root, node_type):
...
@@ -4,30 +4,49 @@ def generate_line(root, node_type):
parentheses.
parentheses.
>>> from node import Node, Leaf
>>> from node import Node, Leaf
>>> #from graph import generate_graph
>>> from graph import generate_graph
>>> l0, l1 = Leaf(1), Leaf(2)
>>> l0, l1 = Leaf(1), Leaf(2)
>>>
n0
= Node('+', l0, l1)
>>>
plus
= Node('+', l0, l1)
>>> print generate_line(
n0
, Node)
>>> print generate_line(
plus
, Node)
1 + 2
1 + 2
>>> n1 = Node('+', l0, l1)
>>> n2 = Node('*', n0, n1)
>>> plus2 = Node('+', l0, l1)
>>> print generate_line(n2, Node)
>>> times = Node('*', plus, plus2)
>>> print generate_line(times, Node)
(1 + 2) * (1 + 2)
(1 + 2) * (1 + 2)
>>> l2 = Leaf(3)
>>> l2 = Leaf(3)
>>>
n3
= Node('-', l2)
>>>
uminus
= Node('-', l2)
>>>
n4 = Node('*', n1, n3
)
>>>
times = Node('*', plus, uminus
)
>>> print generate_line(
n4
, Node)
>>> print generate_line(
times
, Node)
(1 + 2) * -3
(1 + 2) * -3
>>> #integral = Node('int', n0, n1)
>>> exp = Leaf('x')
>>> inf = Leaf('oo')
>>> minus_inf = Node('-', inf)
>>> integral = Node('int', exp, minus_inf, inf)
>>> print generate_line(integral, Node)
int(x, -oo, oo)
"""
"""
operators
=
[
operators
=
[
(
'+'
,
'-'
),
(
'+'
,
'-'
),
(
'mod'
,
),
(
'*'
,
'/'
),
(
'*'
,
'/'
),
(
'^'
,
)
(
'^'
,
)
]
]
max_assoc
=
len
(
operators
)
max_assoc
=
len
(
operators
)
def
is_operator
(
node
):
"""
Check if a given node is an operator (otherwise, it's a function).
"""
label
=
node
.
title
()
either
=
lambda
a
,
b
:
a
or
b
return
reduce
(
either
,
map
(
lambda
x
:
label
in
x
,
operators
))
def
assoc
(
node
):
def
assoc
(
node
):
"""
"""
Get the associativity of an operator node.
Get the associativity of an operator node.
...
@@ -45,8 +64,7 @@ def generate_line(root, node_type):
...
@@ -45,8 +64,7 @@ def generate_line(root, node_type):
"""
"""
The expression tree is traversed using preorder traversal:
The expression tree is traversed using preorder traversal:
1. Visit the root
1. Visit the root
2. Traverse the left subtree
2. Traverse the subtrees in left-to-right order
3. Traverse the right subtree
"""
"""
s
=
node
.
title
()
s
=
node
.
title
()
...
@@ -55,22 +73,28 @@ def generate_line(root, node_type):
...
@@ -55,22 +73,28 @@ def generate_line(root, node_type):
arity
=
len
(
node
)
arity
=
len
(
node
)
if
arity
==
1
:
if
is_operator
(
node
):
# Unary expression
if
arity
==
1
:
s
+=
traverse
(
node
[
0
])
# Unary expression
elif
arity
==
2
:
s
+=
traverse
(
node
[
0
])
# Binary expression
elif
arity
==
2
:
left
,
right
=
map
(
traverse
,
node
)
# Binary expression
left
,
right
=
map
(
traverse
,
node
)
# Check if there is an assiociativity conflict on either side.
# If so, add parentheses
node_assoc
=
assoc
(
node
)
# Check if there is an assiociativity conflict on either side. If
if
assoc
(
node
[
0
])
<
node_assoc
:
# so, add parentheses
left
=
'('
+
left
+
')'
if
assoc
(
node
[
0
])
<
assoc
(
node
):
left
=
'('
+
left
+
')'
if
assoc
(
node
[
1
])
<
assoc
(
node
)
:
if
assoc
(
node
[
1
])
<
node_assoc
:
right
=
'('
+
right
+
')'
right
=
'('
+
right
+
')'
s
=
left
+
' '
+
s
+
' '
+
right
s
=
left
+
' '
+
s
+
' '
+
right
else
:
# Function
s
+=
'('
+
', '
.
join
(
map
(
traverse
,
node
.
nodes
))
+
')'
return
s
return
s
...
...
node.py
View file @
c123d2c4
# vim: set fileencoding=utf-8 :
# vim: set fileencoding=utf-8 :
class
Node
(
object
):
class
Node
(
object
):
def
__init__
(
self
,
label
,
*
nodes
):
def
__init__
(
self
,
label
,
*
nodes
):
self
.
label
,
self
.
nodes
=
label
,
nodes
self
.
label
,
self
.
nodes
=
label
,
list
(
nodes
)
def
__getitem__
(
self
,
n
):
def
__getitem__
(
self
,
n
):
return
self
.
nodes
[
n
]
return
self
.
nodes
[
n
]
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment