A problematic dictionary update (possible Maxima problem)

26 views
Skip to first unread message

Emmanuel Charpentier

unread,
Jun 1, 2024, 4:11:43 PMJun 1
to sage-support

Context : finding patterns of explicit forms of inverse (hyperbolic|trigonometric) functions for simplification.

Simple solution :

reset() y=SR.var("y") IL = [] w0=SR.wild(0) L=[sin, cos, tan, csc, sec, cot, sinh, cosh, tanh, csch, sech, coth] for f in L: R=(f(y)==x).solve(y)[0].rhs() for s in (f(y)==x).exponentialize().solve(y): IL += [s.rhs().subs(x==w0)==R.subs(x==w0)] # End loop

This works. But I’d like to express this list as a dictionary. Brute-force solution fails with a mysterious TypeError: ECL says: THROW: The catch MACSYMA-QUIT is undefined.. But calling this on parts of the list seems to work (not shown).

Try a loop :

ID=dict() for s in IL: ID[s.lhs()]=s.rhs() # End loop

This fails again :

--------------------------------------------------------------------------- RuntimeError Traceback (most recent call last) File /usr/local/sage-10/src/sage/interfaces/interface.py:749, in InterfaceElement.__init__(self, parent, value, is_name, name) 748 try: --> 749 self._name = parent._create(value, name=name) 750 except (TypeError, RuntimeError, ValueError) as x: File /usr/local/sage-10/src/sage/interfaces/maxima_lib.py:632, in MaximaLib._create(self, value, name) 631 else: --> 632 self.set(name, value) 633 except RuntimeError as error: File /usr/local/sage-10/src/sage/interfaces/maxima_lib.py:540, in MaximaLib.set(self, var, value) 539 cmd = '%s : %s$' % (var, value.rstrip(';')) --> 540 self.eval(cmd) File /usr/local/sage-10/src/sage/interfaces/maxima_lib.py:486, in MaximaLib._eval_line(self, line, locals, reformat, **kwds) 485 if statement: --> 486 maxima_eval("#$%s$" % statement) 487 if not reformat: File /usr/local/sage-10/src/sage/libs/ecl.pyx:837, in sage.libs.ecl.EclObject.__call__() 836 """ --> 837 lispargs = EclObject(list(args)) 838 return ecl_wrap(ecl_safe_apply(self.obj, (<EclObject>lispargs).obj)) File /usr/local/sage-10/src/sage/libs/ecl.pyx:698, in sage.libs.ecl.EclObject.__init__() 697 elif len(args) == 1: --> 698 self.set_obj(python_to_ecl(args[0], True)) 699 elif len(args) == 2: File /usr/local/sage-10/src/sage/libs/ecl.pyx:481, in sage.libs.ecl.python_to_ecl() 480 for i in range(len(pyobj) - 1, -1, -1): --> 481 L = cl_cons(python_to_ecl(pyobj[i], read_strings), L) 482 return L File /usr/local/sage-10/src/sage/libs/ecl.pyx:458, in sage.libs.ecl.python_to_ecl() 457 if read_strings: --> 458 return ecl_safe_funcall(read_from_string_clobj, o) 459 else: File /usr/local/sage-10/src/sage/libs/ecl.pyx:342, in sage.libs.ecl.ecl_safe_funcall() 341 else: --> 342 raise RuntimeError("ECL says: {}".format(message)) 343 else: RuntimeError: ECL says: THROW: The catch MACSYMA-QUIT is undefined. During handling of the above exception, another exception occurred: TypeError Traceback (most recent call last) Cell In[231], line 1 ----> 1 load('/tmp/sage_shell_modeSJ8pfj/sage_shell_mode_temp.sage') File /usr/local/sage-10/src/sage/misc/persist.pyx:175, in sage.misc.persist.load() 173 174 if sage.repl.load.is_loadable_filename(filename): --> 175 sage.repl.load.load(filename, globals()) 176 return 177 File /usr/local/sage-10/src/sage/repl/load.py:277, in load(filename, globals, attach) 275 add_attached_file(fpath) 276 with fpath.open() as f: --> 277 exec(preparse_file(f.read()) + "\n", globals) 278 elif ext in ['.spyx', '.pyx']: 279 if attach: File <string>:5 File /usr/local/sage-10/src/sage/symbolic/expression.pyx:3515, in sage.symbolic.expression.Expression.__bool__() 3513 if res in (True, False): 3514 return res -> 3515 res = self.operator()((self.lhs()-self.rhs()).simplify_full(), 0).test_relation() 3516 if res in (True, False): 3517 return res File /usr/local/sage-10/src/sage/symbolic/expression.pyx:10737, in sage.symbolic.expression.Expression.simplify_full() 10735 """ 10736 x = self > 10737 x = x.simplify_factorial() 10738 x = x.simplify_rectform() 10739 x = x.simplify_trig() File /usr/local/sage-10/src/sage/symbolic/expression.pyx:11217, in sage.symbolic.expression.Expression.simplify_factorial() 11215 11216 """ > 11217 return self.parent()(self._maxima_().makefact().factcomb().minfactorial()) 11218 11219 factorial_simplify = simplify_factorial File /usr/local/sage-10/src/sage/symbolic/expression.pyx:1227, in sage.symbolic.expression.Expression._maxima_() 1225 # Maybe not such a great idea because the "default" interface is another one 1226 from sage.calculus.calculus import maxima -> 1227 return super()._interface_(maxima) 1228 else: 1229 return super()._interface_(session) File /usr/local/sage-10/src/sage/structure/sage_object.pyx:724, in sage.structure.sage_object.SageObject._interface_() 722 except Exception: 723 raise NotImplementedError("coercion of object %s to %s not implemented:\n%s\n%s" % (repr(self), I)) --> 724 X = I(s) 725 if c: 726 try: File /usr/local/sage-10/src/sage/interfaces/interface.py:299, in Interface.__call__(self, x, name) 296 pass 298 if isinstance(x, str): --> 299 return cls(self, x, name=name) 300 try: 301 # Special methods do not and should not have an option to 302 # set the name directly, as the identifier assigned by the 303 # interface should stay consistent. An identifier with a 304 # user-assigned name might change its value, so we return a 305 # new element. 306 result = self._coerce_from_special_method(x) File /usr/local/sage-10/src/sage/interfaces/interface.py:751, in InterfaceElement.__init__(self, parent, value, is_name, name) 749 self._name = parent._create(value, name=name) 750 except (TypeError, RuntimeError, ValueError) as x: --> 751 raise TypeError(x) TypeError: ECL says: THROW: The catch MACSYMA-QUIT is undefined.

Diagnosis :

sage: len(IL) 24 sage: len(ID) 20

Hmm. The problem starts with :

sage: IL[len(ID)] log(-sqrt(-$0^2 + 1)/$0 + 1/$0) == arcsech($0)

which can be put in dictionary form :

sage: {IL[len(ID)].lhs():IL[len(ID)].rhs()} {log(-sqrt(-$0^2 + 1)/$0 + 1/$0): arcsech($0)}

But can’t be used for updating the dictionary :

sage: foo=copy(ID)|{IL[len(ID)].lhs():IL[len(ID)].rhs()} --------------------------------------------------------------------------- RuntimeError Traceback (most recent call last) File /usr/local/sage-10/src/sage/interfaces/interface.py:749, in InterfaceElement.__init__(self, parent, value, is_name, name) 748 try: --> 749 self._name = parent._create(value, name=name) 750 except (TypeError, RuntimeError, ValueError) as x: File /usr/local/sage-10/src/sage/interfaces/maxima_lib.py:632, in MaximaLib._create(self, value, name) 631 else: --> 632 self.set(name, value) 633 except RuntimeError as error: File /usr/local/sage-10/src/sage/interfaces/maxima_lib.py:540, in MaximaLib.set(self, var, value) 539 cmd = '%s : %s$' % (var, value.rstrip(';')) --> 540 self.eval(cmd) File /usr/local/sage-10/src/sage/interfaces/maxima_lib.py:486, in MaximaLib._eval_line(self, line, locals, reformat, **kwds) 485 if statement: --> 486 maxima_eval("#$%s$" % statement) 487 if not reformat: File /usr/local/sage-10/src/sage/libs/ecl.pyx:837, in sage.libs.ecl.EclObject.__call__() 836 """ --> 837 lispargs = EclObject(list(args)) 838 return ecl_wrap(ecl_safe_apply(self.obj, (<EclObject>lispargs).obj)) File /usr/local/sage-10/src/sage/libs/ecl.pyx:698, in sage.libs.ecl.EclObject.__init__() 697 elif len(args) == 1: --> 698 self.set_obj(python_to_ecl(args[0], True)) 699 elif len(args) == 2: File /usr/local/sage-10/src/sage/libs/ecl.pyx:481, in sage.libs.ecl.python_to_ecl() 480 for i in range(len(pyobj) - 1, -1, -1): --> 481 L = cl_cons(python_to_ecl(pyobj[i], read_strings), L) 482 return L File /usr/local/sage-10/src/sage/libs/ecl.pyx:458, in sage.libs.ecl.python_to_ecl() 457 if read_strings: --> 458 return ecl_safe_funcall(read_from_string_clobj, o) 459 else: File /usr/local/sage-10/src/sage/libs/ecl.pyx:342, in sage.libs.ecl.ecl_safe_funcall() 341 else: --> 342 raise RuntimeError("ECL says: {}".format(message)) 343 else: RuntimeError: ECL says: THROW: The catch MACSYMA-QUIT is undefined. During handling of the above exception, another exception occurred: TypeError Traceback (most recent call last) Cell In[243], line 1 ----> 1 foo=copy(ID)|{IL[len(ID)].lhs():IL[len(ID)].rhs()} File /usr/local/sage-10/src/sage/symbolic/expression.pyx:3515, in sage.symbolic.expression.Expression.__bool__() 3513 if res in (True, False): 3514 return res -> 3515 res = self.operator()((self.lhs()-self.rhs()).simplify_full(), 0).test_relation() 3516 if res in (True, False): 3517 return res File /usr/local/sage-10/src/sage/symbolic/expression.pyx:10737, in sage.symbolic.expression.Expression.simplify_full() 10735 """ 10736 x = self > 10737 x = x.simplify_factorial() 10738 x = x.simplify_rectform() 10739 x = x.simplify_trig() File /usr/local/sage-10/src/sage/symbolic/expression.pyx:11217, in sage.symbolic.expression.Expression.simplify_factorial() 11215 11216 """ > 11217 return self.parent()(self._maxima_().makefact().factcomb().minfactorial()) 11218 11219 factorial_simplify = simplify_factorial File /usr/local/sage-10/src/sage/symbolic/expression.pyx:1227, in sage.symbolic.expression.Expression._maxima_() 1225 # Maybe not such a great idea because the "default" interface is another one 1226 from sage.calculus.calculus import maxima -> 1227 return super()._interface_(maxima) 1228 else: 1229 return super()._interface_(session) File /usr/local/sage-10/src/sage/structure/sage_object.pyx:724, in sage.structure.sage_object.SageObject._interface_() 722 except Exception: 723 raise NotImplementedError("coercion of object %s to %s not implemented:\n%s\n%s" % (repr(self), I)) --> 724 X = I(s) 725 if c: 726 try: File /usr/local/sage-10/src/sage/interfaces/interface.py:299, in Interface.__call__(self, x, name) 296 pass 298 if isinstance(x, str): --> 299 return cls(self, x, name=name) 300 try: 301 # Special methods do not and should not have an option to 302 # set the name directly, as the identifier assigned by the 303 # interface should stay consistent. An identifier with a 304 # user-assigned name might change its value, so we return a 305 # new element. 306 result = self._coerce_from_special_method(x) File /usr/local/sage-10/src/sage/interfaces/interface.py:751, in InterfaceElement.__init__(self, parent, value, is_name, name) 749 self._name = parent._create(value, name=name) 750 except (TypeError, RuntimeError, ValueError) as x: --> 751 raise TypeError(x) TypeError: ECL says: THROW: The catch MACSYMA-QUIT is undefined.

I’m stymied… Any idea ?

Emmanuel Charpentier

unread,
Jun 1, 2024, 4:17:13 PMJun 1
to sage-support

The damn thing can be done in Sage … by using Sympy :

# Use of Sympy import sympy sx, sy = sympy.symbols("sx, sy") SL = [sympy.sin, sympy.cos, sympy.tan, sympy.csc, sympy.sec, sympy.cot, sympy.sinh, sympy.cosh, sympy.tanh, sympy.csch, sympy.sech, sympy.coth] SIL = [sympy.asin, sympy.acos, sympy.atan, sympy.acsc, sympy.asec, sympy.acot, sympy.asinh, sympy.acosh, sympy.atanh, sympy.acsch, sympy.asech, sympy.acoth] px = sympy.Wild("px") SD={sx:px} foo=[dict(list(map(lambda v:[v.subs(SD), u[0].subs(SD)], u[1]))) for u in zip([w(sx) for w in SIL], [w for w in [sympy.solve((u(sy)-sx).rewrite("exp"), sy) for u in SL]])] sD=dict() for d in foo:sD|=d # Conversion to Sage Dic2={u._sage_().subs({px:w0}):sD[u]._sage_().subs({px:w0}) for u in sD.keys()}

Indeed :

sage: Dic2 {-I*log(I*$0 - I*sqrt($0^2 - 1)): arcsin($0), -I*log(I*$0 + I*sqrt($0^2 - 1)): arcsin($0), -I*log($0 - sqrt($0^2 - 1)): arccos($0), -I*log($0 + sqrt($0^2 - 1)): arccos($0), -I*log(-sqrt(-($0 - I)/($0 + I))): arctan($0), -I*log(sqrt(-($0 - I)/($0 + I))): arctan($0), -I*log(-(sqrt($0^2 - 1) - I)/$0): arccsc($0), -I*log((sqrt($0^2 - 1) + I)/$0): arccsc($0), -I*log(-(sqrt(-$0^2 + 1) - 1)/$0): arcsec($0), -I*log((sqrt(-$0^2 + 1) + 1)/$0): arcsec($0), -I*log(-sqrt(($0 + I)/($0 - I))): arccot($0), -I*log(sqrt(($0 + I)/($0 - I))): arccot($0), log($0 - sqrt($0^2 + 1)): arcsinh($0), log($0 + sqrt($0^2 + 1)): arcsinh($0), log($0 - sqrt($0^2 - 1)): arccosh($0), log($0 + sqrt($0^2 - 1)): arccosh($0), log(-sqrt(-($0 + 1)/($0 - 1))): arctanh($0), log(sqrt(-($0 + 1)/($0 - 1))): arctanh($0), log(-(sqrt($0^2 + 1) - 1)/$0): arccsch($0), log((sqrt($0^2 + 1) + 1)/$0): arccsch($0), log(-(sqrt(-$0^2 + 1) - 1)/$0): arcsech($0), log((sqrt(-$0^2 + 1) + 1)/$0): arcsech($0), log(-sqrt(($0 + 1)/($0 - 1))): arccoth($0), log(sqrt(($0 + 1)/($0 - 1))): arccoth($0)}

But the need for this workaround makes me suspect thai it might not be as useful as I wish it would be…

Hints ? Ideas ?

[ Even lazzi are welcome… ]

Reply all
Reply to author
Forward
0 new messages