Author Topic: Is this a _FLOAT or VAL() bug?  (Read 4254 times)

0 Members and 1 Guest are viewing this topic.

Offline Pete

  • Forum Resident
  • Posts: 2361
  • Cuz I sez so, varmint!
    • View Profile
Is this a _FLOAT or VAL() bug?
« on: March 17, 2019, 09:55:16 pm »
Code: QB64: [Select]
  1. WIDTH 80, 43
  2. s$ = "1"
  3. FOR i = 1 TO 20
  4.     s$ = "0" + s$
  5.     x$ = "." + s$
  6.     x## = VAL(x$)
  7.     PRINT " "; x$, LEN(x$) - 1
  8.     PRINT x##

  [ You are not allowed to view this attachment ]  

OK, two things. Why does it put a trailing zero at .000000000010? It should be tn zeros, and a one. Next, why does it skip 1D-20? Everything after that is one digit off.

Single gives correct results. Double gives the same incorrect results as _FLOAT.

Pete
« Last Edit: March 17, 2019, 10:07:44 pm by Pete »
Want to learn how to write code on cave walls? https://www.tapatalk.com/groups/qbasic/qbasic-f1/

Offline SMcNeill

  • QB64 Developer
  • Forum Resident
  • Posts: 3972
    • View Profile
    • Steve’s QB64 Archive Forum
Re: Is this a _FLOAT or VAL() bug?
« Reply #1 on: March 17, 2019, 10:23:14 pm »
If I took a guess, I’d say it’s probably a rounding issue at 1D-20.
https://github.com/SteveMcNeill/Steve64 — A github collection of all things Steve!

Offline jack

  • Seasoned Forum Regular
  • Posts: 408
    • View Profile
Re: Is this a _FLOAT or VAL() bug?
« Reply #2 on: March 17, 2019, 10:27:21 pm »
the las two entries look wrong to me, here's what I get with FB using double
Code: QB64: [Select]
  1. .............
  2.  .0000000000000000001        19
  3. 1e-19
  4.  .00000000000000000001       20
  5. 9.999999999999999e-21
  6.  .000000000000000000001      21
  7. 9.999999999999999e-22
  8.  
here using 80-bit
Code: QB64: [Select]
  1. .......................
  2.  .0000000000000001           16
  3. 1e-16
  4.  .00000000000000001          17
  5. 1e-17
  6.  .000000000000000001         18
  7. 1e-18
  8.  .0000000000000000001        19
  9. 1e-19
  10.  .00000000000000000001       20
  11. 1e-20
  12.  .000000000000000000001      21
  13. 1e-21
  14.  
« Last Edit: March 17, 2019, 10:29:00 pm by jack »

Offline Pete

  • Forum Resident
  • Posts: 2361
  • Cuz I sez so, varmint!
    • View Profile
Re: Is this a _FLOAT or VAL() bug?
« Reply #3 on: March 17, 2019, 10:32:06 pm »
The FB results are more the rounding errors I would expect. Not being off by a full power of 10. What did to print for #11? That's the one I showed that had a trailing zero that shouldn't be present.

Pete
Want to learn how to write code on cave walls? https://www.tapatalk.com/groups/qbasic/qbasic-f1/

Offline jack

  • Seasoned Forum Regular
  • Posts: 408
    • View Profile
Re: Is this a _FLOAT or VAL() bug?
« Reply #4 on: March 17, 2019, 10:41:19 pm »
for 11 I get (double)
Code: QB64: [Select]
  1.  .00000000001  11
  2. 9.999999999999999e-12
  3.  

Offline Pete

  • Forum Resident
  • Posts: 2361
  • Cuz I sez so, varmint!
    • View Profile
Re: Is this a _FLOAT or VAL() bug?
« Reply #5 on: March 17, 2019, 10:54:38 pm »
Thanks. I'm wondering what QB rendered for double. double and _FLOAT are the same. Single is accurate. Maybe QB had the off by power of 10 rounding error for d-20, too.

Pete
Want to learn how to write code on cave walls? https://www.tapatalk.com/groups/qbasic/qbasic-f1/

Offline jack

  • Seasoned Forum Regular
  • Posts: 408
    • View Profile
Re: Is this a _FLOAT or VAL() bug?
« Reply #6 on: March 17, 2019, 11:18:09 pm »
I thought that this variation would give the right output, but no.
Code: QB64: [Select]
  1. WIDTH 80, 43
  2. s$ = "1"
  3. FOR i = 1 TO 20
  4.     s$ = "0" + s$
  5.     x$ = "." + s$ + "##"
  6.     x## = VAL(x$)
  7.     PRINT " "; x$, LEN(x$) - 3
  8.     PRINT x##
  9.  
however, pcbasic, which is a gwbasic emulator gives
Code: QB64: [Select]
  1.  .00000000001#               11
  2.  .00000000001
  3.  .000000000001#              12
  4.  .000000000001
  5.  .0000000000001#             13
  6.  .0000000000001
  7.  .00000000000001#            14
  8.  .00000000000001
  9.  .000000000000001#           15
  10.  .000000000000001
  11.  .0000000000000001#          16
  12.  .0000000000000001
  13.  .00000000000000001#         17
  14. 1D-17
  15.  .000000000000000001#        18
  16. 1D-18
  17.  .0000000000000000001#       19
  18. 1D-19
  19.  .00000000000000000001#      20
  20. 1D-20
  21.  .000000000000000000001#     21
  22. 1D-21
  23.  

Offline Qwerkey

  • Forum Resident
  • Posts: 755
    • View Profile
Re: Is this a _FLOAT or VAL() bug?
« Reply #7 on: March 18, 2019, 07:33:58 am »
It does behave properly if you start with

s$ = "11" or s$ = "101"

How interesting.  Computers, eh?

Offline Qwerkey

  • Forum Resident
  • Posts: 755
    • View Profile
Re: Is this a _FLOAT or VAL() bug?
« Reply #8 on: March 18, 2019, 07:40:01 am »
Also, try it with:

Code: QB64: [Select]
  1. WIDTH 80, 43
  2. s$ = "1"
  3. FOR i = 1 TO 20
  4.     s$ = "0" + s$
  5.     x$ = "." + s$
  6.     x## = VAL(x$)
  7.     PRINT " "; x$, LEN(x$) - 1
  8.     PRINT x##, 1.1 * x##

Offline jack

  • Seasoned Forum Regular
  • Posts: 408
    • View Profile
Re: Is this a _FLOAT or VAL() bug? more anomalies
« Reply #9 on: March 18, 2019, 08:56:27 am »
the following code
Code: QB64: [Select]
  1. ldx = 5## / 9##
  2. PRINT ldx
  3. PRINT USING "##.##################^^^"; ldx
  4. PRINT USING "##.##################^^^^"; ldx
  5.  
output
Code: QB64: [Select]
  1.  .5555555555555556
  2. 0.555555555555555556^^^
  3. 0.555555555555555556F+00
  4.  

Offline jack

  • Seasoned Forum Regular
  • Posts: 408
    • View Profile
Re: Is this a _FLOAT or VAL() bug?
« Reply #10 on: March 18, 2019, 09:23:23 am »
tested on Windows
Code: QB64: [Select]
  1. DIM ldx AS _FLOAT ', x AS _FLOAT
  2. PRINT "variable arithmetic on _FLOAT have DOUBLE precision on QB64 64-bit, OK on QB64 32-bit"
  3. FOR x## = 1## TO 8##
  4.     ldx = x## / 9##
  5.     PRINT ldx
  6.     PRINT USING "##.##################^^^^"; ldx
  7. PRINT "you can assign a _FLOAT constant expression OK"
  8. ldx = 8## / 9##
  9. PRINT USING "##.##################^^^^"; ldx
  10.  
QB64 32-bit
Quote
variable arithmetic on _FLOAT have DOUBLE precision on QB64 64-bit, OK on QB64 32-bit
 .1111111111111111
 0.111111111111111111F+00
 .2222222222222222
 0.222222222222222222F+00
 .3333333333333333
 0.333333333333333333F+00
 .4444444444444444
 0.444444444444444444F+00
 .5555555555555556
 0.555555555555555556F+00
 .6666666666666666
 0.666666666666666667F+00
 .7777777777777778
 0.777777777777777778F+00
 .8888888888888888
 0.888888888888888889F+00
you can assign a _FLOAT constant expression OK
 0.888888888888888889F+00
QB64 64-bit
Quote
variable arithmetic on _FLOAT have DOUBLE precision on QB64 64-bit, OK on QB64 32-bit
 .1111111111111111
 0.111111111111111105F+00
 .2222222222222222
 0.222222222222222210F+00
 .3333333333333333
 0.333333333333333315F+00
 .4444444444444444
 0.444444444444444420F+00
 .5555555555555556
 0.555555555555555580F+00
 .6666666666666666
 0.666666666666666630F+00
 .7777777777777778
 0.777777777777777790F+00
 .8888888888888888
 0.888888888888888840F+00
you can assign a _FLOAT constant expression OK
 0.888888888888888889F+00
« Last Edit: March 18, 2019, 09:28:07 am by jack »

Offline Jack002

  • Forum Regular
  • Posts: 123
  • Boss, l wanna talk about arrays
    • View Profile
Re: Is this a _FLOAT or VAL() bug?
« Reply #11 on: March 18, 2019, 04:03:23 pm »
The top post here by Pete,
first, I see 1D-20 near the bottom where you see 1D-21. I looked at the recip, got what I expect, then I did a recip of the recip. I didn't always get the original value. Seems there is a bug.

Code: QB64: [Select]
  1. WIDTH 80, 43
  2. s$ = "1"
  3. FOR i = 1 TO 20
  4.     s$ = "0" + s$
  5.     x$ = "." + s$
  6.     x## = VAL(x$)
  7.     PRINT x$, LEN(x$) - 1
  8.     PRINT x##, 1 / x##, 1 / (1 / x##)
  9.  
  10.  
  11.  

2nd observation, the log base 10 is NOT the exponent every time. It should be

Code: QB64: [Select]
  1. WIDTH 80, 43
  2.  
  3. CALL look(".00000000000000000001")
  4. CALL look(".000000000000000000001")
  5. CALL look(".0000000000000000000001")
  6.  
  7.  
  8. SUB look (i$)
  9.     x## = VAL(i$)
  10.     PRINT i$, LEN(i$) - 1
  11.     PRINT x##, LOG(x##) / LOG(10.0)
  12.  
« Last Edit: March 18, 2019, 04:22:31 pm by Jack002 »
QB64 is the best!