Difference between revisions of "BinaryDecimalConverter"

From Second Life Wiki
Jump to navigation Jump to search
m (<lsl> tag to <source>)
 
(2 intermediate revisions by 2 users not shown)
Line 1: Line 1:
{{LSL Header}}
{{LSL Header}}
The next function converts a binary value to a decimal number. Works +/- 5 times faster than [[Base2Dec]] :
The next function converts a binary value to a decimal number. Works +/- 5 times faster than [[Base2Dec]] :
<lsl>
<source lang="lsl2">integer binToDec(string val)
integer binToDec(string val)
{
{
     integer dec;
     integer dec = 0;
   
     integer i = ~llStringLength(val);
     integer i = -llStringLength(val);
     while(++i)
   
     while(++i < 0)
    {
         dec = (dec << 1) + (integer)llGetSubString(val, i, i);
         dec = (dec << 1) + (integer)llGetSubString(val, i, i);
    }
     return dec;
     return dec;
}
}</source>
</lsl>


This one converts a decimal to a binary value:
This one converts a decimal to a binary value:


<lsl>
<source lang="lsl2">string decToBin(integer val)
string decToBin(integer val)
{
{
     string binary;
     string binary = (string)(val & 1);
     integer i = val;
     for(val = ((val >> 1) & 0x7FFFffff); val; val = (val >> 1))
    while (i)
     {
     {
         if (i % 2)
         if (val & 1)
             binary = "1" + binary;
             binary = "1" + binary;
         else
         else
             binary = "0" + binary;
             binary = "0" + binary;
       
        i = i >> 1;
     }
     }
     return binary;
     return binary;
}
}</source>
</lsl>


Greets from Soundless :)
Greets from Soundless :)
This version of decToBin doesn't crash on negatives, is shorter source code and about 50 bytes shorter in Mono bytecode than the original, but sadly about 50% slower. << and >> are expensive on bytecode.
<source lang="lsl2">
string decToBin(integer val)
{
    string binary;
    do
        binary = (string) (val & 1) + binary;
    while (val /= 2);
    return binary;
}
</source>
((Omei))

Latest revision as of 18:27, 24 January 2015

The next function converts a binary value to a decimal number. Works +/- 5 times faster than Base2Dec :

integer binToDec(string val)
{
    integer dec = 0;
    integer i = ~llStringLength(val);
    while(++i)
        dec = (dec << 1) + (integer)llGetSubString(val, i, i);
    return dec;
}

This one converts a decimal to a binary value:

string decToBin(integer val)
{
    string binary = (string)(val & 1);
    for(val = ((val >> 1) & 0x7FFFffff); val; val = (val >> 1))
    {
        if (val & 1)
            binary = "1" + binary;
        else
            binary = "0" + binary;
    }
    return binary;
}

Greets from Soundless :)

This version of decToBin doesn't crash on negatives, is shorter source code and about 50 bytes shorter in Mono bytecode than the original, but sadly about 50% slower. << and >> are expensive on bytecode.

string decToBin(integer val)
{
    string binary;
    do
        binary = (string) (val & 1) + binary;
    while (val /= 2);
    return binary;
}

((Omei))