bug in if()

bug in if() - immediate evaluation behind line() - Messages

#1 Posted: 3/26/2022 8:49:18 AM
Martin_B

Martin_B

21 likes in 84 posts.

Group: User

Hi!

Is this a bug in if()?

It turns to a real problem e.g. when used in a case like shown in the example.

bug_if.png
bug_if.sm (15 KiB) downloaded 36 time(s).
#2 Posted: 3/26/2022 9:18:52 PM
overlord

overlord

547 likes in 1330 posts.

Group: Moderator

Wrote

Hi!

Is this a bug in if()?

It turns to a real problem e.g. when used in a case like shown in the example


Yes, it is a bug.

if() function doesn't like plotting, solvers, custom functions as in your example, etc.

You have to use cases() for that kind of usages.

Regards
#3 Posted: 3/29/2022 6:08:28 AM
Davide Carpi

Davide Carpi

1415 likes in 2872 posts.

Group: Moderator

Just to clarify, this is not a fault in the specific function, it works this way because the current architecture of the core doesn't allows a different implementation (thus can't be simply fixed with a change in the function itself).

if(...) currently requires the condition argument to be defined on evaluation, otherwise an error is thrown; this makes the if/else instructions sealed from further evaluations of the preprocessor.

As opposite cases(...) doesn't throw errors on simbolic conditions, but this makes instructions evaluable (thus you shouldn't add any definition in the case() arguments).



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
sergio 3/29/2022 10:15:00 AM
  • New Posts New Posts
  • No New Posts No New Posts