Oxygen Basic
Programming => Example Code => General => Topic started by: Aurel on August 07, 2014, 12:00:59 PM
-
wait...
what a heck this string work here...?
#qNAN
this is the string which often jump in string error operations
it looks that is not random sequence of chars....or maybe is ::)
-
Aurel,
NAN stands for not-a-number which is a conventional way to denote a numeric quantity that cannot be expressed correctly in terms of a computer floating-point number using its current exponent and mantissa bit fields. Despite a tremendous variety of possible floating-point numbers, not every value within 32-bit, 64-bit, and 80-bit ranges can be expressed with a given number of bits allowed for the value's exponent and mantissa bit fields.
Charles,
Is this #qNAN thingy just a printable flag for a too-close-to-zero-hence-NAN exception or does it have a definite mathematical meaning in this context? Do you have a matching something for INF?
-
John,
It is primarily something to include in source code but could also become a DLL. Passing and returning C strings to make it more accessible.
Mike,
#qNAN is returned for indeterminate numbers from expressions like 0/0
#INF for positive infinity 1/0
#-INF for negative infinity -1/0 or 1/-0
It is legit to use infinty expressions in Oxygen calculations, but anything that produces #qNAN will always cause the calculation to result in #qNAN
-
Thanks Charles!
Are they initialized transparently by the engine or explicitly by the user e.g. as
#INF = 1/0
#-INF = -1/0
#qNAN = 0/0
?
Can #INFinities and #qNAN's be used in (in)equality evaluations as literals?
And finally, why #qNAN?
Pooh! :)
-
These are strings generated internally by float_to_ascii
To use infinities in calculations and comparisons, it is easiest to create variables holding these values:
float zero=0.0, mzero=-0.0, inf=1/0, minf=-1/0, nan=0/0
NAN cannot be used directly in float comparisons, so its bit-coding must be checked instead:
if ?f=?nan ...
PS: qNAN means quiet NAN. It is not disruptive to FPU operations.
-
Thanks again, Charles!
You're in a bad need of a dedicated chroniqueur. Too much valuable info is getting lost and scattered all over the forum. :)
-
Well, most of the examples go into OxygenBasic.zip, though we are getting to the stage where a database is needed to manage them :)
Float Case Ranges
float zero=0.0, mzero=-0.0, inf=1/0, minf=-1/0, nan=0/0
float f
'f=0.0 'zero
'f=-0.0 'minus zero
'f=1/0 'infinity
'f=-1/0 'minus infinity
'f=0/0 'not a number
'f=.19999999999999999 'range boundary test
f=.20
'f=.2125
'
'THESE CASES USE DWORD (SYS) MATCHING INSTEAD OF FLOAT EVALUATION
select ?f
case ?zero : print "zero"
case ?mzero : print "minus zero"
case ?inf : print "infinity"
case ?minf : print "minus infinity"
case ?nan : print "nan (not a number)"
case else
'CASES USING NORMAL FLOAT EVALUATION
select f
case 0.0 to < 0.1 : print "0.0 to < 0.1 : " str f,2
case 0.1 to < 0.2 : print "0.1 to < 0.2 : " str f,2
case 0.2 to < 0.3 : print "0.2 to < 0.3 : " str f,2
end select
end select