AReaL/evaluation/latex2sympy/asciimath_printer.py

67 lines
1.8 KiB
Python

from sympy.core import S
from sympy.printing.str import StrPrinter
class AsciiMathPrinter(StrPrinter):
def _print_Limit(self, expr):
e, z = expr.args
return "lim_(%s -> %s) %s" % (self._print(z), self._print(z), self._print(e))
def _print_Integral(self, expr):
e, lims = expr.args
if len(lims) > 1:
return "int_(%s)^(%s) %s d%s" % (
self._print(lims[1]),
self._print(lims[2]),
self._print(e),
self._print(lims[0]),
)
else:
return "int %s d%s" % (self._print(e), self._print(lims))
def _print_Sum(self, expr):
e, lims = expr.args
return "sum_(%s = %s)^(%s) %s" % (
self._print(lims[0]),
self._print(lims[1]),
self._print(lims[2]),
self._print(e),
)
def _print_Product(self, expr):
e, lims = expr.args
return "prod_(%s = %s)^(%s) %s" % (
self._print(lims[0]),
self._print(lims[1]),
self._print(lims[2]),
self._print(e),
)
def _print_factorial(self, expr):
return "%s!" % self._print(expr.args[0])
def _print_Derivative(self, expr):
e = expr.args[0]
wrt = expr.args[1]
return "d/d%s %s" % (self._print(wrt), self._print(e))
def _print_Abs(self, expr):
return "|%s|" % self._print(expr.args[0])
def _print_Equality(self, expr):
return "%s = %s" % (self._print(expr.args[0]), self._print(expr.args[1]))
def _print_Pow(self, expr):
b = self._print(expr.base)
if expr.exp is S.Half:
return "sqrt(%s)" % b
if -expr.exp is S.Half:
return "1/sqrt(%s)" % b
if expr.exp is -S.One:
return "1/%s" % b
return "%s^(%s)" % (b, self._print(expr.exp))