Difference between revisions of "LlFabs"

From Second Life Wiki
Jump to navigation Jump to search
m
(like llAbs, llFabs isn't strictly necessary, though can't bitshift so avoiding the function isn't quite as powerful and it produces NaNs for infinity/+0 for -0)
 
(4 intermediate revisions by 4 users not shown)
Line 7: Line 7:
|return_type=float
|return_type=float
|return_text=that is the positive version of {{LSLP|val}}.
|return_text=that is the positive version of {{LSLP|val}}.
|other_languages={{LSL OL|C++|[http://www.cplusplus.com/reference/clibrary/cmath/fabs/ fabs]}}
|other_languages={{LSL OL|C++|[http://www.cplusplus.com/reference/cmath/fabs/ fabs]}}
|spec
|spec
|caveats
|caveats
|examples=
|examples=
<lsl>
<source lang="lsl2">
default
default
{
{
Line 21: Line 21:
// returns :
// returns :
// The (Float)absolute value of -4.5 is: 4.500000
// The (Float)absolute value of -4.5 is: 4.500000
</lsl>
</source>
|helpers
|helpers
|also_functions={{LSL DefineRow||[[llAbs]]|[[integer]] version of llFabs}}
|also_functions={{LSL DefineRow||[[llAbs]]|[[integer]] version of llFabs}}
|also_events
|also_events
|also_articles={{LSL DefineRow||{{Wikipedia|Absolute value}}|}}
|also_articles={{LSL DefineRow||{{Wikipedia|Absolute value}}|}}
|notes
|notes=*Using <code>{{LSLP|val}}-2*{{LSLP|val}}*({{LSLP|val}}<0)</code> is roughly 60% faster than llFabs as it avoids a function call, though it produces {{abbr|NaN|not a number}} if given an infinite value and (correctly) returns 0.0 instead of -0.0 when taking the absolute value of negative zero.
|cat1=Math
|cat1=Math
|cat2=Float
|cat2=Float
|cat3
|cat3
|cat4
|cat4
|haiku={{Haiku|Even with all your little bits intact,|down to the final point|it's still size that matters.}}
}}
}}

Latest revision as of 14:11, 28 October 2023

Summary

Function: float llFabs( float val );
0.0 Forced Delay
10.0 Energy

Returns a float that is the positive version of val.

• float val Any valid float value
This function is similar to functions (e.g. fabs) found in many other languages: 
C++
fabs

Examples

default
{
    state_entry()
    {
        llSay(0,"The (Float)absolute value of -4.5 is: "+(string)llFabs(-4.5) );
    }
}
// returns :
// The (Float)absolute value of -4.5 is: 4.500000

Notes

  • Using val-2*val*(val<0) is roughly 60% faster than llFabs as it avoids a function call, though it produces NaN if given an infinite value and (correctly) returns 0.0 instead of -0.0 when taking the absolute value of negative zero.

See Also

Functions

•  llAbs integer version of llFabs

Articles

•  "Wikipedia logo"Absolute value

Deep Notes

Signature

function float llFabs( float val );

Haiku

Even with all your little bits intact,
down to the final point
it's still size that matters.