Skip to content

Commit fa5d938

Browse files
authored
Merge pull request #384 from rikardn/unicode
Add unicode function
2 parents ff6b99d + 7c57599 commit fa5d938

File tree

5 files changed

+16
-3
lines changed

5 files changed

+16
-3
lines changed

symengine/__init__.py

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -29,7 +29,8 @@
2929
FunctionSymbol as AppliedUndef,
3030
golden_ratio as GoldenRatio,
3131
catalan as Catalan,
32-
eulergamma as EulerGamma
32+
eulergamma as EulerGamma,
33+
unicode
3334
)
3435
from .utilities import var, symbols
3536
from .functions import *

symengine/lib/symengine.pxd

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1103,6 +1103,7 @@ cdef extern from "<symengine/printers.h>" namespace "SymEngine":
11031103
string ccode(const Basic &x) nogil except +
11041104
string latex(const Basic &x) nogil except +
11051105
string latex(const DenseMatrix &x, unsigned max_rows, unsigned max_cols) nogil except +
1106+
string unicode(const Basic &x) nogil except +
11061107

11071108
## Defined in 'symengine/cwrapper.cpp'
11081109
cdef struct CRCPBasic:

symengine/lib/symengine_wrapper.pyx

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -5471,6 +5471,11 @@ def latex(expr):
54715471
basic_expr = sympify(expr)
54725472
return symengine.latex(deref(basic_expr.thisptr)).decode("utf-8")
54735473

5474+
def unicode(expr):
5475+
cdef Basic basic_expr
5476+
basic_expr = sympify(expr)
5477+
return symengine.unicode(deref(basic_expr.thisptr)).decode("utf-8")
5478+
54745479
cdef _flattened_vec(symengine.vec_basic &vec, exprs):
54755480
cdef Basic b
54765481
if is_sequence(exprs):

symengine/tests/test_printing.py

Lines changed: 7 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
from symengine import (ccode, Symbol, sqrt, Pow, Max, sin, Integer, MutableDenseMatrix)
1+
from symengine import (ccode, unicode, Symbol, sqrt, Pow, Max, sin, Integer, MutableDenseMatrix)
22
from symengine.utilities import raises
33
from symengine.printing import CCodePrinter, init_printing
44

@@ -30,3 +30,9 @@ def test_init_printing():
3030
assert x._repr_latex_() is None
3131
init_printing()
3232
assert x._repr_latex_() == '$x$'
33+
34+
35+
def test_unicode():
36+
x = Symbol("x")
37+
y = Integer(2)
38+
assert unicode(x / 2) == "x\n\n2"

symengine_version.txt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1 +1 @@
1-
36ac51d06e248657d828bfa4859cff32ab5f03ba
1+
v0.9.0

0 commit comments

Comments
 (0)