# plotlib.py, svg plot generator by Reinier Heeres # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA # # Change log: # 2007-09-04: rwh, first version import types import logging _logger = logging.getLogger('PlotLib') class PlotLib: """Class to generate an svg plot for a function. Evaluation of values is done using the EqnParser class.""" def __init__(self, parser): self.parser = parser self.svg_data = "" self.set_size(0, 0) def set_size(self, width, height): self.width = width self.height = height def get_svg(self): return self.svg_data def parse_range(self, range): p1 = range.split('=') if len(p1) != 2: return None p2 = p1[1].split('..') if len(p2) != 2: return None return (p1[0], (float(p2[0]), float(p2[1]))) def evaluate(self, eqn, var, range, n=100): x_old = self.parser.get_var(var) res = [] d = float((range[1] - range[0])) / (n - 1) x = range[0] while n > 0: self.parser.set_var(var, x) v = float(self.parser.parse(eqn)) res.append((x, v)) x += d n -= 1 self.parser.set_var(var, x_old) return res def create_image(self): self.svg_data = '\n' self.svg_data += '\n' self.svg_data += '\n' % (self.width, self.height) def finish_image(self): self.svg_data += '' def plot_line(self, c0, c1, col): c0 = self.rcoords_to_coords(c0) c1 = self.rcoords_to_coords(c1) self.svg_data += '\n' % (col, c0[0], c0[1], c1[0], c1[1]) def plot_polyline(self, coords, col): self.svg_data += '\n' def add_text(self, c, text, rotate=0): if type(text) is types.UnicodeType: text = text.encode('utf-8') c = self.rcoords_to_coords(c) self.svg_data += '