Author Topic: Language  (Read 8992 times)

0 Members and 1 Guest are viewing this topic.

Offline Colonel_Panic

  • Newbie
  • Posts: 54
    • View Profile
Language
« on: November 07, 2021, 10:23:19 pm »
This is the first place online where I have *seen* stuff just like mine.
which makes me feel sort of "at home" I suppose.

LANGUAGE
=======
I have seen stuff like this called a "math module", and its a good description.
it continually asks you for an "expression to evaluate".

you are making variable assignments;
 the variable list "grows" at the top of the screen
if you enter:
x=2
y=3
z=((x*2)+(y*4))/2

you can watch as it keeps track and performs the evaluation(s)

this module, one just like it... is always my "ground zero" if I
am going to do any kind of "make my own language" work. Which is
why its called "language". I have used these routines several times in the past, they never fail me.

this is a stripped down special version, where it stops and shows you, step by step,
each "pass" as it reduces the math expression. In real life, it just SPITS it back out,
it seems instantaneous.

In one of my projects, I might have to calculate algebraic expressions, out of a $string.
this module will obviously be re-purposed for that.

LINUX MINT executable:
 

got code?

Code: QB64: [Select]
  1. NumVars = 0
  2. DIM VN$(128), VV(128)
  3.  
  4. AnotherExpression:
  5. FOR t = 1 TO NumVars
  6.   PRINT VN$(t); " ="; VV(t)
  7. PRINT "Enter expression to evaluate :";
  8. PRINT "-----------------------------"
  9. 'strip the spaces; meaningless in a math expression
  10. N1$ = ""
  11. FOR t = 1 TO LEN(z$)
  12.   IF MID$(z$, t, 1) <> " " THEN N1$ = N1$ + MID$(z$, t, 1)
  13. z$=N1$
  14. 'check for assignment
  15. VarFlag = 0
  16. FOR t = 2 TO LEN(z$)
  17.   IF MID$(z$, t, 1) = "=" THEN
  18.     GOSUB Assign:
  19.     IF VarFlag > 0 THEN z$ = EXP$: GOTO Start:
  20.   END IF
  21.  
  22. Start:
  23. pErrL = 0: pErrR = 0 'checks L's = R's
  24. pErr = 0 'other error(s)
  25. FOR t = 1 TO LEN(z$) 'check # of P's match
  26.   IF MID$(z$, t, 1) = "(" THEN pErrL = pErrL + 1
  27.   IF MID$(z$, t, 1) = ")" THEN pErrR = pErrR + 1
  28. IF (pErrL <> pErrR) THEN
  29.   PRINT "Fatal Error; (="; pErrL; "and )="; pErrR
  30.   PRINT "press <ENTER> :";: LINE INPUT nothing$
  31.   CLS: GOTO AnotherExpression:
  32. pErrL = 0: pErrR = 0
  33. FOR t = 1 TO LEN(z$)
  34.   IF MID$(z$, t, 1) = "(" THEN pErrL = pErrL + 1
  35.   IF MID$(z$, t, 1) = ")" THEN pErrR = pErrR + 1
  36.   IF pErrL = 0 AND pErrR = 1 THEN
  37.     PRINT "Fatal Error; 1st Paren must be a ("
  38.     PRINT "press <ENTER> :";: LINE INPUT nothing$
  39.     CLS: GOTO AnotherExpression:
  40.   END IF
  41.  
  42. pErrL = 0: pErrR = 0
  43. FOR t = LEN(z$) TO 1 STEP -1
  44.   IF MID$(z$, t, 1) = "(" THEN pErrL = pErrL + 1
  45.   IF MID$(z$, t, 1) = ")" THEN pErrR = pErrR + 1
  46.   IF pErrL = 1 AND pErrR = 0 THEN
  47.     PRINT "Fatal Error; last Paren must be a )"
  48.     PRINT "press <ENTER> :";: LINE INPUT nothing$
  49.     CLS: GOTO AnotherExpression
  50.   END IF
  51.  
  52. 'done error trapping;
  53. ' add Paren's to force one pass and contain any ops
  54. z$ = "(" + z$ + ")"
  55.  
  56. RunAgain:
  57. hasP = 0
  58. FOR t = 1 TO LEN(z$)
  59.   IF (MID$(z$, t, 1) = "(") OR (MID$(z$, t, 1) = ")") THEN hasP = 1
  60. IF hasP = 1 THEN GOTO Find_inner_paren:
  61. IF hasP = 0 THEN
  62.   PRINT "done, final value ="; z$
  63.   IF VarFlag > 0 THEN
  64.     VV(VarFlag) = VAL(z$)
  65.   END IF
  66. PRINT "press <ENTER> :";
  67. LINE INPUT nothing$
  68. CLS: GOTO AnotherExpression:
  69.  
  70. Find_inner_paren:
  71.  
  72. Find_left_paren:
  73. FOR t1 = 1 TO LEN(z$) - 1
  74.   IF MID$(z$, t1, 1) = "(" THEN
  75.     GOSUB Find_Right_Paren:
  76.     IF rpFlag <> 0 THEN
  77.       lft$ = LEFT$(z$, t1 - 1)
  78.       rht$ = RIGHT$(z$, LEN(z$) - rpFlag)
  79.       ' PRINT "."; lft$; "."; rht$; ".": END
  80.       GOSUB Eval:
  81.       z$ = lft$ + LTRIM$(STR$(zval)) + rht$
  82.       GOTO RunAgain:
  83.     END IF
  84.   END IF
  85. NEXT t1
  86.  
  87. '--------------------subroutine Find_Right_Paren:-------------
  88. 'driven entirely by Find_Left_Paren:
  89. Find_Right_Paren:
  90. rpFlag = 0
  91. FOR t2 = t1 + 1 TO LEN(z$)
  92.   IF MID$(z$, t2, 1) = "(" THEN
  93.     rpFlag = 0
  94.     RETURN
  95.   END IF
  96.   IF MID$(z$, t2, 1) = ")" THEN
  97.     rpFlag = t2
  98.     RETURN
  99.   END IF
  100. NEXT t2
  101. rpFlag = 0: RETURN
  102. '--------------------END subroutine Find_Right_Paren:----------
  103.  
  104. '------------------subroutine Eval:----------------------------
  105. 'we are always working at the innermost Paren's
  106. 'this routine reduces it to a value one operation at a time
  107. Eval:
  108. z1$ = MID$(z$, t1, t2 - t1 + 1)
  109. EvalAgain:
  110.  
  111. FOR t3 = 1 TO LEN(z1$)
  112.   IF MID$(z1$, t3, 1) = "^" THEN op$ = "^": GOSUB EvalAdd:: GOTO EvalAgain:
  113. NEXT t3
  114.  
  115. FOR t3 = 1 TO LEN(z1$)
  116.   IF MID$(z1$, t3, 1) = "*" THEN op$ = "*": GOSUB EvalAdd:: GOTO EvalAgain:
  117.   IF MID$(z1$, t3, 1) = "/" THEN op$ = "/": GOSUB EvalAdd:: GOTO EvalAgain:
  118. NEXT t3
  119.  
  120. FOR t3 = 1 TO LEN(z1$)
  121.   IF MID$(z1$, t3, 1) = "+" THEN op$ = "+": GOSUB EvalAdd:: GOTO EvalAgain:
  122.   IF MID$(z1$, t3, 1) = "-" THEN op$ = "-": GOSUB EvalAdd:: GOTO EvalAgain:
  123. NEXT t3
  124. GOSUB ReplaceVar:
  125. PRINT "no more ops; value = "; z1$
  126. zval = VAL(MID$(z1$, 2, LEN(z1$) - 2))
  127. '--------------------END subroutine Eval:---------------------
  128.  
  129. '--------------------subroutine EvalAdd:----------------------
  130. 'performs the actual OPeration(s) when called by Eval:
  131. EvalAdd:
  132. FOR t5 = t3 - 1 TO 2 STEP -1
  133.   IF INSTR("^*/+-", MID$(z1$, t5, 1)) <> 0 THEN
  134.     Lend = t5 + 1: GOTO GotLeft:
  135.   END IF
  136. NEXT t5
  137. Lend = 2
  138. GotLeft:
  139. L1$ = MID$(z1$, Lend, t3 - Lend)
  140. FOR t4 = t3 + 1 TO LEN(z1$)
  141.   IF INSTR("^*/+-", MID$(z1$, t4, 1)) <> 0 THEN
  142.     Rend = t4: GOTO GotRite:
  143.   END IF
  144. NEXT t4
  145. Rend = LEN(z1$)
  146. GotRite:
  147. R1$ = MID$(z1$, t3 + 1, Rend - (t3 + 1))
  148. GOSUB ReplaceVars:
  149. PRINT L1$; " "; op$; " "; R1$; " = ";
  150. IF op$ = "+" THEN res$ = LTRIM$(STR$(VAL(L1$) + VAL(R1$)))
  151. IF op$ = "-" THEN res$ = LTRIM$(STR$(VAL(L1$) - VAL(R1$)))
  152. IF op$ = "*" THEN res$ = LTRIM$(STR$(VAL(L1$) * VAL(R1$)))
  153. IF op$ = "/" THEN res$ = LTRIM$(STR$(VAL(L1$) / VAL(R1$)))
  154. IF op$ = "^" THEN res$ = LTRIM$(STR$(VAL(L1$) ^ VAL(R1$)))
  155.  
  156. z1$ = LEFT$(z1$, Lend - 1) + res$ + RIGHT$(z1$, LEN(z1$) - Rend + 1)
  157. PRINT z1$
  158.  
  159. '--------------------END EvalAdd:-----------------------------
  160.  
  161. '--------------subroutine Assign:-----------------------------
  162. 'sets up a variable assignment to the expression
  163. Assign:
  164. VarFlag = 0
  165. Epl = t
  166. NAM$ = LEFT$(z$, Epl - 1)
  167. EXP$ = RIGHT$(z$, LEN(z$) - Epl)
  168.  
  169. namErr = 0
  170. FOR t1 = 1 TO LEN(NAM$) 'legal var names are A-Z, 0-9, a-z, and _ ;cant start with a #
  171.   ch$ = MID$(NAM$, t1, 1)
  172.   IF t1 > 1 AND ch$ >= "0" AND ch$ <= "9" THEN GOTO DuLast: 'cant start with #
  173.   IF ch$ >= "A" AND ch$ <= "Z" THEN GOTO DuLast:
  174.   IF ch$ >= "a" AND ch$ <= "z" THEN GOTO DuLast:
  175.   IF ch$ = "_" THEN GOTO DuLast:
  176.   namErr = namErr + 1
  177.   DuLast:
  178. NEXT t1
  179. IF namErr > 0 THEN
  180.   VarFlag = 0
  181.   PRINT "Fatal Error; illegal variable name"
  182.   PRINT "press <enter> :";
  183.   LINE INPUT nothing$
  184.  
  185. IF NumVars = 0 THEN
  186.   NumVars = NumVars + 1
  187.   VN$(NumVars) = NAM$
  188.   VarFlag = NumVars
  189.   GOTO DuLast2:
  190. IF NumVars > 0 THEN
  191.   FOR t1 = 1 TO NumVars
  192.     IF NAM$ = VN$(t1) THEN
  193.       VarFlag = t1
  194.       GOTO DuLast2:
  195.     END IF
  196.   NEXT t1
  197. 'add new variable
  198. NumVars = NumVars + 1
  199. VN$(NumVars) = NAM$
  200. VarFlag = NumVars
  201. DuLast2:
  202. '------------------END subroutine Assign:----------------------
  203.  
  204.  
  205. '--------------subroutine ReplaceVars:-------------------------
  206. 'checks for operands being variables
  207. ReplaceVars:
  208. FOR t9 = 1 TO NumVars
  209.   IF VN$(t9) = L1$ THEN L1$ = LTRIM$(STR$(VV(t9)))
  210.   IF VN$(t9) = R1$ THEN R1$ = LTRIM$(STR$(VV(t9)))
  211. NEXT t9
  212. '-----------------END subroutine ReplaceVars:------------------
  213.  
  214.  
  215. '----------------subroutine ReplaceVar:------------------------
  216. 'catches case of a variable not being an operand
  217. ReplaceVar:
  218. chNam$ = MID$(z1$, 2, LEN(z1$) - 2)
  219. FOR t9 = 1 TO NumVars
  220.   IF VN$(t9) = chNam$ THEN z1$ = "(" + LTRIM$(STR$(VV(t9))) + ")"
  221. NEXT t9
  222. '-------------------END subroutine ReplaceVar:-----------------
  223.  
  224.  
« Last Edit: November 07, 2021, 10:28:22 pm by Colonel_Panic »

Offline Colonel_Panic

  • Newbie
  • Posts: 54
    • View Profile
Re: Language
« Reply #1 on: November 07, 2021, 11:04:54 pm »
it is *supposed* to do:

addition, subtraction, multiplication, division, exponent

if you peek at the code around line 120+ you will see where "any operation"
between 2 values, the operand could easily be inserted and the result calculated.
fairly easy to add math operations one at a time to get your library going.
I always stayed pretty "lean" and didnt ask it to do much beyond reduce algebraic.

What I do, is I check a string... and if it starts with a VARIABLE followed by an equals sign,
 then this module is a go.
If I am doing ARRAYS? I will want more than straight integer numbers, the end user
 of my software will expect to have algebraic equations for array indexes, like any programmer
 needs. This module?

well... its a STRING, and its surrounded by PARENTHESIS... the module automatically spits back the
 array index. If its a integer index, fine. if its a variable index, thats fine too. If the index of the array
 reference is an algebraic equation of existing variable assignments? Hey, it spits back the result.

if the STRING isnt a variable name followed by an equals sign?
Then its probably a COMMAND, and I would then search a list of commands in a string array.
take appropriate action.

NOTE: this is not "the actual code" I used twice before; I recreated it because I have done it a
  couple times before. If you can "trip it up" and prove it makes a parenthetical or order of operations error? That's good work on your part.
« Last Edit: November 07, 2021, 11:10:26 pm by Colonel_Panic »

Offline Ed Davis

  • Newbie
  • Posts: 40
    • View Profile
Re: Language
« Reply #2 on: November 09, 2021, 06:22:40 am »
it is *supposed* to do:

addition, subtraction, multiplication, division, exponent

...

NOTE: this is not "the actual code" I used twice before; I recreated it because I have done it a
  couple times before. If you can "trip it up" and prove it makes a parenthetical or order of operations error? That's good work on your part.

Pretty cool!

I did notice one problem - it gets:


Code: QB64: [Select]
  1. -2^-3^-4
  wrong.  For instance, in QB64, the answer is:



(https://www.qb64.org/forum/)


However, in the posted code, the above loops:


(https://www.qb64.org/forum/)




The QB64 IDE also gets it wrong too, so you're in good company!




(https://www.qb64.org/forum/)


(https://www.qb64.org/forum/)



Hmmm.  Not sure why the pictures pasted from the clipboard didn't come through.  They looked fine on this end :(

Anyway, the answer from QB64 is:  -0.9914792

However, the IDE Math Tool gets 4096, and the posted code just loops.

Again, very cool, and thanks for sharing!

« Last Edit: November 09, 2021, 06:32:59 am by Ed Davis »

Offline SMcNeill

  • QB64 Developer
  • Forum Resident
  • Posts: 3972
    • View Profile
    • Steve’s QB64 Archive Forum
Re: Language
« Reply #3 on: November 09, 2021, 06:32:05 am »
-2^-3^-4

With the images goofed up, I can't see what the results were, but I'd suspect your expectations are wrong.

-2^-3^-4...  I'm expecting you think that's a NEGATIVE 2 there, don't you?

How about if I write it as:  0 - 2 ^ -3 ^ -4

Now, isn't that a MINUS in front of that 2?

By order of precedence, we do powers before subtraction, so that minus is evaluated last.  I'm guessing what you want is (-2) ^ -3 ^ -4 for your answer.
https://github.com/SteveMcNeill/Steve64 — A github collection of all things Steve!

Offline Ed Davis

  • Newbie
  • Posts: 40
    • View Profile
Re: Language
« Reply #4 on: November 09, 2021, 06:53:47 am »
-2^-3^-4

With the images goofed up, I can't see what the results were, but I'd suspect your expectations are wrong.

-2^-3^-4...  I'm expecting you think that's a NEGATIVE 2 there, don't you?

How about if I write it as:  0 - 2 ^ -3 ^ -4

Now, isn't that a MINUS in front of that 2?

By order of precedence, we do powers before subtraction, so that minus is evaluated last.  I'm guessing what you want is (-2) ^ -3 ^ -4 for your answer.

I was simply testing it.

In the QB64 IDE running:

print -2^-3^-4

Shows:  -.9914792

Are you saying that is wrong?

The IDE math tool gives 4096.

Google calculator returns:

-0.99147913749

I think QB64, google calc (and various other eval/calc programs) are correct, and the IDE math tool is wrong.

« Last Edit: November 09, 2021, 06:59:34 am by Ed Davis »

Offline SMcNeill

  • QB64 Developer
  • Forum Resident
  • Posts: 3972
    • View Profile
    • Steve’s QB64 Archive Forum
Re: Language
« Reply #5 on: November 09, 2021, 06:59:33 am »
I don't "want" anything :)

I was simply testing it.

In the QB64 IDE running:

print -2^-3^-4

Shows:  -.9914792

Are you saying that is wrong?

And the math tool gives 4096.

The google calculator returns:

-0.99147913749

I think QB64, google calc (and various other eval/calc programs) are correct, and the IDE math tool is wrong.

Of the math tool is showing 4096, it's definitely wrong.  I'll dig into it when I get some freetime (which might be after the holidays).  Thanks for reporting the issue -- the math tool is the same math which CONST uses to calculate values, so if it's wrong, CONST probably would be as well.
https://github.com/SteveMcNeill/Steve64 — A github collection of all things Steve!

Offline david_uwi

  • Newbie
  • Posts: 71
    • View Profile
Re: Language
« Reply #6 on: November 09, 2021, 07:35:54 am »
-2^-3^-4 evaluating left to right...
-2^-3=(1/-2)^3=-1/8
(-1/8)^-4=-8^4=4096

FellippeHeitor

  • Guest
Re: Language
« Reply #7 on: November 09, 2021, 07:47:52 am »
@SMcNeill We have been discussing for a while now on Discord to replace the custom math interpreter entirely and make CONSTs "fake consts" - that is - have them be regular variables, have QB64 evaluate them at runtime, not at compile time, and just set a "don't change" flag so they are treated as consts. There's a lot to figure - scope, for instance, but that's the trending idea in the dev lounge right now.

Offline SMcNeill

  • QB64 Developer
  • Forum Resident
  • Posts: 3972
    • View Profile
    • Steve’s QB64 Archive Forum
Re: Language
« Reply #8 on: November 09, 2021, 08:23:48 am »
-2^-3^-4 evaluating left to right...
-2^-3=(1/-2)^3=-1/8
(-1/8)^-4=-8^4=4096

Even this is wrong...   That -2 in front of the 2 should be processed last as a minus sign.

Guys, run this little demo and you'll see that the math evaluator is all messed in -- in ALL cases in QB64 -- for this type of math problem:

Code: QB64: [Select]
  1. Screen _NewImage(1024, 720, 32)
  2.  
  3. Print "Let's establish what happens when we have a minus number raised to a power: -2 ^ 2 = "; -2 ^ 2
  4. Print "Order of Operations says we solve powers over subtraction, so we get -4, not 4."
  5. Print "So let's solve the equation for -2 ^ -3 ^ -4 with that in mind:"
  6. x = 2 ^ -3
  7. y = x ^ -4
  8.  
  9. Print "- 2 ^ -3 ^ -4"
  10. Print "-"; x; " ^ -4"
  11. Print "-"; y
  12.  
  13. Print "The true solution *should* be -4096 and not +4096."
  14. Print "Somewhere along the way processing, that minus changes from minus to negative and then gets powered out to a positive..."
  15. Print "Which, it really shouldn't do..."
  16. Print "But a +4096 is much more reliable of an answer than "; -2 ^ -3 ^ -4
  17. Print "How the heck do we get that anyway??"
  18.  
  19. Print "Another way to do this problem is by multiplying powers:"
  20. Print "For example:   x ^ y ^ z is the same as x ^ (y * z)"
  21. Print "(From Power of a Power Property of Exponent)"
  22. Print "So in this case, we get -2 ^ -3 ^ -4 as being the exact same as -2 ^ (-3 * -4) = -2 ^ 12."
  23. Print "And, if we solve it like before, we get:"; -2 ^ 12
  24. Print "If we count that - in front of the two as a minus, the result is -4096."
  25. Print "If it's a negation symbol, the answer is +4096."
  26. Print "Either way, it shouldn't be "; -2 ^ -3 ^ -4
  27.  

The math evaluator is *almost* right, but it swaps that minus over to a negative at some point and loses track of it.

-2 ^ -3 - ^ -4 is the same as -2 ^ (-3 * -4), or -2 ^ 12 -- and that answer is -4096.
https://github.com/SteveMcNeill/Steve64 — A github collection of all things Steve!

Offline SMcNeill

  • QB64 Developer
  • Forum Resident
  • Posts: 3972
    • View Profile
    • Steve’s QB64 Archive Forum
Re: Language
« Reply #9 on: November 09, 2021, 08:38:42 am »
@SMcNeill We have been discussing for a while now on Discord to replace the custom math interpreter entirely and make CONSTs "fake consts" - that is - have them be regular variables, have QB64 evaluate them at runtime, not at compile time, and just set a "don't change" flag so they are treated as consts. There's a lot to figure - scope, for instance, but that's the trending idea in the dev lounge right now.

It'd kind of defeat the purpose of CONST, but it wouldn't upset me any.  All these edge cases in math are crazy, but in this case QB64's normal evaluation methods are terribly crazy. 

The only way to get the 0.9 result is if we count the negation in ^ -3 as a minus:
x = 3 ^ -4
y = -2 ^ -x
Print y

With that a minus 3, rather than a negative 3, we'd do our power first, like above.

It's all goofed up!  :P

Honestly, if it's evaluating as I think it is, I'd expect it to error out on us just from trying to work two math operations without any value between them -- the minus and the power. 

You can't divide divide //
You can't multiply multiply **
Why can you exponent subtract ^-

That should be an exponent negation, not an exponent subtraction in there. 
https://github.com/SteveMcNeill/Steve64 — A github collection of all things Steve!

Offline SMcNeill

  • QB64 Developer
  • Forum Resident
  • Posts: 3972
    • View Profile
    • Steve’s QB64 Archive Forum
Re: Language
« Reply #10 on: November 09, 2021, 09:03:40 am »
@BSpinoza  -- The problem is with how you deal with that leading minus.

In example 2, you count it as (-2 ^ -3), setting the result as a negative value you then deal with.

After that, however, you keep the two separate: PRINT -2 ^ (-3 ^ -4)

Try a simple:  PRINT -2 ^ 2.   The answer is -4, not +4, as that minus comes after the exponents are finished.  Your second example should be -(2 ^ -3) ^ -4), if we're going to stick to the same order as we do with -2 ^ 2.

It's all goofy.  Or, if it isn't, I need a *LOT* more coffee to understand why we're gettingthe results we are.

PRINT (-2) ^ (-3 ^ -4) ends up giving as a positive number, instead of a negative, after all.
https://github.com/SteveMcNeill/Steve64 — A github collection of all things Steve!

Offline SMcNeill

  • QB64 Developer
  • Forum Resident
  • Posts: 3972
    • View Profile
    • Steve’s QB64 Archive Forum
Re: Language
« Reply #11 on: November 09, 2021, 09:18:40 am »
What we're doing is - (2 ^ - (3 ^ - (4)))...  Powers over negation.  None of those are negative numbers; they're all evaluated as negation operations.

Anyone who doesn't use parentheses for these type of formulas are just crazy.
https://github.com/SteveMcNeill/Steve64 — A github collection of all things Steve!

FellippeHeitor

  • Guest
Re: Language
« Reply #12 on: November 09, 2021, 09:26:33 am »
To be very honest with you all, all that matters to me is that this:

 
Captura de Tela 2021-11-09 às 11.24.54.png


Results in the same as this:

 
Captura de Tela 2021-11-09 às 11.23.45.png
 
Captura de Tela 2021-11-09 às 11.24.05.png

Offline bplus

  • Global Moderator
  • Forum Resident
  • Posts: 8053
  • b = b + ...
    • View Profile
Re: Language
« Reply #13 on: November 09, 2021, 11:06:12 am »
+1 with Fellippe and BSpinoza.

Very interesting problem and BSinoza explained issue that Power is like Division not Communitive.

BTW Oh Interpreter would make you say p[-2,p[-3,-4]] or p[p[-2,-3],-4] ie forcing to pick which is to be done 1st and 2nd. * Gold Star for it ;-))
Update: well it did this for one:
Quote
p{p{-2,-3},-4} = 4096

and for the other it called an error,
 
oh test -2^-3^-4.PNG

It's saying the answer is a complex number!


A expression with a leading minus (separated from number by space) should force an error IMHO, or the minus is assumed to reverse(+/-) the number value immediately to the right like - -2 = 2 or - 2 = -2.
« Last Edit: November 09, 2021, 11:29:02 am by bplus »

Offline SMcNeill

  • QB64 Developer
  • Forum Resident
  • Posts: 3972
    • View Profile
    • Steve’s QB64 Archive Forum
Re: Language
« Reply #14 on: November 09, 2021, 11:37:03 am »
@bplus -- you must've missed this:

What we're doing is - (2 ^ - (3 ^ - (4)))...  Powers over negation.  None of those are negative numbers; they're all evaluated as negation operations.

For proof, try this little code:

Code: QB64: [Select]
  1. Print -(2 ^ -(3 ^ -(4)))
  2. Print -2 ^ -3 ^ -4

And for the love of God, can somebody explain why the BEEP PRINT is printing different levels of precision here?  I thought we printed to SINGLE precision by default.  How does adding a parenthesis suddenly give us DOUBLE precision? 

EDIT:

When using powers of powers, you multiply the exponents together.

https://www.mtsac.edu/marcs/worksheet/general_topics/11properties_exponents.pdf#:~:text=not%20present%20%20%20Properties%20%20%20,%20%18%13%01%0E%17%08%14%20%20%203%20more%20rows%20

 
SS.png


Since we solve left to right,

x^2^3 is the same as (x^2) ^ 3, which makes the answer x ^ 6.

In this case, if those are negative numbers, it'd be:
-2 ^ - 3 ^ -4
- 2 ^ 12
4096

But QB64 doesn't count ANY of those as negative numbers.  Instead, it counts them as negation operators.  (ie X = -X)

negate (2 ^ negate (3 ^ negate (4)))
« Last Edit: November 09, 2021, 11:46:35 am by SMcNeill »
https://github.com/SteveMcNeill/Steve64 — A github collection of all things Steve!