[SS-3568] try/onerror issue

[SS-3568] try/onerror issue - Messages

#1 Posted: 10/5/2018 3:33:54 PM
Alvaro Diaz Falconi

Alvaro Diaz Falconi

992 likes in 1674 posts.

Group: User

Hi. There are not try-catch here.

Clipboard01.gif

Best regards.
Alvaro.
#2 Posted: 10/5/2018 9:01:23 PM
Jean Giraud

Jean Giraud

983 likes in 6866 posts.

Group: User

Wrote

There are not try-catch here.



There are not too many applications in this forum.
It works numerically ... visit this application.

Jean

Image Rotate RGB Copy.sm (349 KiB) downloaded 31 time(s).
#3 Posted: 10/6/2018 9:21:26 AM
Alvaro Diaz Falconi

Alvaro Diaz Falconi

992 likes in 1674 posts.

Group: User

This seems to be a workaround for the bug.

Clipboard01.gif

Length_Try_Catch.sm (8 KiB) downloaded 24 time(s).

Functions like this Length, and equivalents for Rows and Cols are a standard way in Mathcad to check if one works with matrices or scalars, avoiding the use of IsMatrix (absent in SMath at this time), and saving some program steps.

Best regards.
Alvaro.

PD: Try-catch is the name in Maple and others for the SMath try-on error.
1 users liked this post
frapuano 10/6/2018 9:28:00 AM
#4 Posted: 10/6/2018 10:15:00 AM
Davide Carpi

Davide Carpi

1415 likes in 2872 posts.

Group: Moderator

Added in the BTS as SS-3568


P.S. as for now, if you have custom functions:

2018-10-06 15_14_15-Window.png
If you like my plugins please consider to support the program buying a license; for personal contributions to me: paypal.me/dcprojects
#5 Posted: 10/6/2018 11:36:17 PM
Alvaro Diaz Falconi

Alvaro Diaz Falconi

992 likes in 1674 posts.

Group: User

Wrote

Added in the BTS as SS-3568


P.S. as for now, if you have custom functions:

2018-10-06 15_14_15-Window.png



Hi Davide. Thanks.
Best regards. For the plugin and for add as issue.
Alvaro
#6 Posted: 10/7/2018 2:32:15 AM
Alvaro Diaz Falconi

Alvaro Diaz Falconi

992 likes in 1674 posts.

Group: User

With this version of IsMatrix you catch the length for symbolic matrices. Also, avoiding the use of strings have some advantages over the simple version, here as IsMat.

Length.sm (48 KiB) downloaded 37 time(s).

Clipboard01.gif

Best regards.
Alvaro
#7 Posted: 10/30/2018 12:35:13 PM
Andrey Ivashov

Andrey Ivashov

2269 likes in 3730 posts.

Group: Super Administrator

Described behavior of the try...catch is by design.

In your example length(x) calculated symbolically and does not raise an error. You can check it by calculating length(x) with symbolic optimization.
To have the behavior you want please use eval(lenght(x)) instead.

Best regards.
#8 Posted: 10/30/2018 4:08:18 PM
Alvaro Diaz Falconi

Alvaro Diaz Falconi

992 likes in 1674 posts.

Group: User

Wrote

Described behavior of the try...catch is by design.

Best regards.



Hi Andrey. Thanks for the clarification. I guess that the origin of this behavior is from about which is the "default unassigned variable type" in SMath. In maple and mathcad it is a complex number, but in SMath it seems to be a matrix or anything else:

Clipboard03.gif

If this is the case, it's correct to return rows, cols and length as an error in numerical evaluations and unevaluated form in symbolic ones.

For other side, it seems that if actuate like having something like evalb (maple's eval boolean), forcing the numerical evaluation, as it is showed in the yellow regions, and widely apply in the attached. This behavior is very useful, at least to me, because enable following routines for Length, Rows, Cols, IsMatrix (without using num2str which causes some issues for some applications) and others useful tools, which yield the same result for numeric and symbolic evaluations, making more easy the live to me.

Length.sm (61 KiB) downloaded 39 time(s).

Best regards.
Alvaro.

PD: It seems that in the attached file I change the default font color, but don't know how, neither how to revert it to black.
1 users liked this post
frapuano 10/31/2018 3:18:00 AM
#9 Posted: 10/31/2018 7:40:04 AM
Davide Carpi

Davide Carpi

1415 likes in 2872 posts.

Group: Moderator

Wrote

Hi Andrey. Thanks for the clarification. I guess that the origin of this behavior is from about which is the "default unassigned variable type" in SMath. In maple and mathcad it is a complex number, but in SMath it seems to be a matrix or anything else


Unassigned variables are considered as unknown type; there were problems in the past because they were consider scalar or matrices...

Clipboard03.gif
I suggest to open a separate correction request here or in the bug tracker to improve behavior of length/rows/cols when a matrix contains unknowns...
If you like my plugins please consider to support the program buying a license; for personal contributions to me: paypal.me/dcprojects
1 users liked this post
Alvaro Diaz Falconi 10/31/2018 9:57:00 PM
#10 Posted: 10/31/2018 7:22:50 PM
Jean Giraud

Jean Giraud

983 likes in 6866 posts.

Group: User

... plenty of things will reflect in "on-error"

Maths on_error.sm (15 KiB) downloaded 29 time(s).
#11 Posted: 10/31/2018 10:06:16 PM
Alvaro Diaz Falconi

Alvaro Diaz Falconi

992 likes in 1674 posts.

Group: User

Hi Davide. Thanks for your answer.

Wrote


Unassigned variables are considered as unknown type; there were problems in the past because they were consider scalar or matrices...



Good to know. So, the results for rows, length, etc. it's correct. I don't have enough time nor ideas about how to test try...on error function, but guess that it is correcto too.

Wrote


I suggest to open a separate correction request here or in the bug tracker to improve behavior of length/rows/cols when a matrix contains unknowns...



Thanks for the suggestion. But don't know what could be more convenient. For instance, maple have evalb (booleans), evalm (matrix, but obsolete in news versions), evalc (complexes) and some others for modify the way that evaluations are done. Also, the eval maple's function is like the "at" function in the Custom Functions plugin. So, maybe instead of modify rows and those functions, could be more practical introduce a second argument for eval, of the type of "complex", or "scalar", or "matrix" or things like this. Or maybe there are some simplify function under development which can handle those cases, or ... I actually don't know enogh for say which is the best path to follow.

Best regards.
Alvaro.
#12 Posted: 11/2/2018 3:58:04 PM
Jean Giraud

Jean Giraud

983 likes in 6866 posts.

Group: User

Wrote

Described behavior of the try...catch is by design.



What should it do that is missing ? Catch errors piecewise in program ?

Cheers ... Jean
  • New Posts New Posts
  • No New Posts No New Posts