hexadecimal calculations

Dar Scott dsc at swcp.com
Thu Jan 27 17:12:50 EST 2005


On Jan 26, 2005, at 10:00 PM, Paul Salyers wrote:

> will the computer (REV) do math calculations with hexadecimal without 
> converting it to decimal?

Internally Revolution uses a standard floating point representation 
with a binary point.

When math is presented with a value that is the result of arithmetic, 
it uses it as is.  If it is a numeral (text meaning a number), it 
converts first.  It can handle a wide range of numerals.  The numerals 
are assumed to be decimal (base 10) unless prefixed with "0x" which 
means hex.  Either kind of numeral may use "E" notation, a computereze 
version of scientific notation.

Most people don't put quote marks around numerals, but it does not hurt 
to do that.

If the result of arithmetic is used as a string it is converted using 
the current local value of the numberFormat property.  It will convert 
the result of arithmetic to a decimal numeral, but since the number is 
stored internally with a binary point and not a decimal point, the 
fractional part may be off by a tiny bit.

The result of arithmetic (or any numberal) can be converted to a string 
with the format() function which allows hexidecimal formatting, but it 
does not work for the fractional part.

Also, the baseConvert() function can be used to convert numerals.  This 
uses a 32-bit whole number intermediate value, so conversions are 
limited by that.

For example:

on mouseUp
   put "0xA.8" into a
   put (a+2) && format("%x",a + 17)
end mouseUp

==>

12.5 1c


Dar

**********************************************
     DSC (Dar Scott Consulting & Dar's Lab)
     http://www.swcp.com/dsc/
     Programming Services and Software
**********************************************



More information about the use-livecode mailing list