+
+ def plot(self):
+ import matplotlib.pyplot as plt
+ from matplotlib.path import Path
+ import matplotlib.patches as patches
+
+ if len(self.symbols)> 3:
+ raise TypeError
+
+ elif len(self.symbols) == 2:
+ verts = self.vertices()
+ points = []
+ codes = [Path.MOVETO]
+ for vert in verts:
+ pairs = ()
+ for sym in sorted(vert, key=Symbol.sortkey):
+ num = vert.get(sym)
+ pairs = pairs + (num,)
+ points.append(pairs)
+ points.append((0.0, 0.0))
+ num = len(points)
+ while num > 2:
+ codes.append(Path.LINETO)
+ num = num - 1
+ else:
+ codes.append(Path.CLOSEPOLY)
+ path = Path(points, codes)
+ fig = plt.figure()
+ ax = fig.add_subplot(111)
+ patch = patches.PathPatch(path, facecolor='blue', lw=2)
+ ax.add_patch(patch)
+ ax.set_xlim(-5,5)
+ ax.set_ylim(-5,5)
+ plt.show()
+
+ elif len(self.symbols)==3:
+ return 0
+
+ return points