Author Topic: QB64 Oddness at Work  (Read 4388 times)

0 Members and 1 Guest are viewing this topic.

Offline SMcNeill

  • QB64 Developer
  • Forum Resident
  • Posts: 3972
    • View Profile
    • Steve’s QB64 Archive Forum
QB64 Oddness at Work
« on: January 08, 2020, 01:57:47 am »
I really love the first few results from this simple code:

Code: QB64: [Select]
  1. PRINT "QB64 at work:"
  2. PRINT "PRINT 34000000000000000000000000000000000000000"
  3. PRINT 34000000000000000000000000000000000000000
  4. PRINT "PRINT x = 34000000000000000000000000000000000000000"
  5. x = 34000000000000000000000000000000000000000
  6. PRINT "x = "; x
  7. PRINT "PRINT 34000000000000000000000000000000000000000##"
  8. PRINT 34000000000000000000000000000000000000000##
  9. PRINT "PRINT x = 34000000000000000000000000000000000000000##"
  10. x = 34000000000000000000000000000000000000000##
  11. PRINT "x = "; x
  12. PRINT "PRINT x## = 34000000000000000000000000000000000000000##"
  13. x## = 34000000000000000000000000000000000000000##
  14. PRINT "x## = "; x##
  15. PRINT "PRINT 34000000000000000000000000000000000000000."
  16. PRINT 34000000000000000000000000000000000000000.
  17.  

And then compare the first one to the last one...

There's no DEFINT, DEFLNG, or anything in this code which would change our default types to integers, and yet the first couple of results *appear* as if they might be set by an integer limit....

The thing is, LOOK close.  The value we see, compared to our INTEGER64 signed and unsigned limits is below:

12,354,918,591,714,295,808  -- the value we get printed, and assigned.
 9,223,372,036,854,775,807  -- the signed INT64 limit.
18,446,744,073,709,551,615  -- the unsigned INT64 limit.


So it translates the value to something greater than what a signed integer64 can hold, yet it doesn't make it the limit of what an unsigned integer64 can hold...  Just where the heck does that 123... come from??  And why does our value become that one??? 

QB64 is utterly baffling me with how it produces the results it does for us sometimes...
https://github.com/SteveMcNeill/Steve64 — A github collection of all things Steve!

Offline Qwerkey

  • Forum Resident
  • Posts: 755
    • View Profile
Re: QB64 Oddness at Work
« Reply #1 on: January 08, 2020, 05:03:37 am »
Just where the heck does that 123... come from??  And why does our value become that one??? 


Also try:
Code: QB64: [Select]
  1. PRINT "PRINT 32000000000000000000000000000000000000000"
  2. PRINT 32000000000000000000000000000000000000000

A slightly lower number which gives a larger final printout.

Baffling indeed!  Just what is happening in the processing of the large decimal number into binary and why doesn't it stay fixed at default variable limit as you say???

This is the difference with dumb machines.  The human 'machine' would simply output: "Stop giving me silly numbers".

(and by the way, Fellippe, what are you doing up at this time?!).
« Last Edit: January 08, 2020, 05:04:50 am by Qwerkey »

Offline SMcNeill

  • QB64 Developer
  • Forum Resident
  • Posts: 3972
    • View Profile
    • Steve’s QB64 Archive Forum
Re: QB64 Oddness at Work
« Reply #2 on: January 08, 2020, 05:10:29 am »
Maybe it’s overflow and the number we’re seeing is MOD 18,446,744,073,709,551,615?

STx can check that with string math for us, I think.  ;)
https://github.com/SteveMcNeill/Steve64 — A github collection of all things Steve!

Offline Qbee

  • Newbie
  • Posts: 27
    • View Profile
Re: QB64 Oddness at Work
« Reply #3 on: January 08, 2020, 07:48:08 am »
Watching the results made me think of "Weird Scenes Inside the Goldmine".
Long forgotten ... thank you for make me think of that.

Offline Pete

  • Forum Resident
  • Posts: 2361
  • Cuz I sez so, varmint!
    • View Profile
Re: QB64 Oddness at Work
« Reply #4 on: January 08, 2020, 10:57:52 am »
Maybe start working on a new version: QB-LGBTQ. It's like QB64, but completely non-binary.

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

Offline Qbee

  • Newbie
  • Posts: 27
    • View Profile
Re: QB64 Oddness at Work
« Reply #5 on: January 08, 2020, 12:05:24 pm »
Watching the results made me think of "Weird Scenes Inside the Goldmine".
Long forgotten ... thank you for make me think of that.
Couldn't resist - went into the city and bought it - AGAIN.

Offline Richard Frost

  • Seasoned Forum Regular
  • Posts: 316
  • Needle nardle noo. - Peter Sellers
    • View Profile
Re: QB64 Oddness at Work
« Reply #6 on: January 26, 2020, 01:06:06 am »

I understand what big numbers like that mean.  You are building a really
big television that will use all material in the Universe. 

It starts with hanging one led off a serial port, 8 off a parallel port,
then arrays interfaced directly to the bus, and now this, a dastardly
plan to make everything blink. 

An agent of UNICEF is onto you.
It works better if you plug it in.

Offline SMcNeill

  • QB64 Developer
  • Forum Resident
  • Posts: 3972
    • View Profile
    • Steve’s QB64 Archive Forum
Re: QB64 Oddness at Work
« Reply #7 on: January 26, 2020, 01:48:31 am »

I understand what big numbers like that mean.


Actually, it just means I was testing the new math evaluation routines for use with CONST, and I noticed some really odd results.  I spent hours trying to debug the glitch in my math stuff, only to figure out in the end that QB64 itself was producing the oddness.  ;D
https://github.com/SteveMcNeill/Steve64 — A github collection of all things Steve!

Offline bplus

  • Global Moderator
  • Forum Resident
  • Posts: 8053
  • b = b + ...
    • View Profile
Re: QB64 Oddness at Work
« Reply #8 on: January 26, 2020, 09:58:06 am »
I ran into a problem like that with Deal Or No Deal. The suit case prize amounts run from 1 million dollars down to 1 cent, can you print .01 from data as double type formatted with commas and dollar sign? Not before going through hell! .01 internally gets changed to 9.99blahblah D -blahblah

Offline OldMoses

  • Seasoned Forum Regular
  • Posts: 469
    • View Profile
Re: QB64 Oddness at Work
« Reply #9 on: January 30, 2020, 07:15:13 pm »
Actually, it just means I was testing the new math evaluation routines for use with CONST, and I noticed some really odd results.  I spent hours trying to debug the glitch in my math stuff, only to figure out in the end that QB64 itself was producing the oddness.  ;D

I feel your pain. I too, was spending hours trying to debug some gravity routines that weren't working right. They did fine with small stars and planets, but would choke when presented with a low density supergiant star. The computations require the squaring and cubing of vast distances and I knew the size of the numbers was the issue. Although _INTEGER64 can hold the numbers, QB64 does not seem to like using them in those computations, even though the result goes into a _FLOAT. I had to convert the integers to floats before running them through the arguments, then all was well. Until I did that all sorts of goofy answers were the norm.