diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2018-11-16 07:26:54 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2018-11-16 07:26:54 -0800 |
commit | 877cb438262b5ab98e25ae88fa66d9f22aace9cd (patch) | |
tree | cb5cbefd20ee198f8a62f9ad5701037ff83120c7 /arith.c | |
parent | edc808bf0ccba62aee1a5e49ae31baebdfc1c9a5 (diff) | |
download | txr-877cb438262b5ab98e25ae88fa66d9f22aace9cd.tar.gz txr-877cb438262b5ab98e25ae88fa66d9f22aace9cd.tar.bz2 txr-877cb438262b5ab98e25ae88fa66d9f22aace9cd.zip |
compiler: use binary versions of common math functions.
* arith.c (arith_init): Register functions in the sys package:
b<, b>, b<=, b=, b+, b-, b*, b/ and neg.
* share/txr/stdlib/compiler.tl (%nary-ops%, %bin-ops%,
%bin-op%): New global variables.
(compiler comp-fun-form): Transform two-argument calls to any
of the variadic functions in %nary-ops% functions into calls
to their binary counterpart. These calls are faster, since
they bypass the wrapper which deals with the variable argument
list. Also, we detect unary - and map it to the new sys:neg
function, and reduce the one-argument cases of certain
functions to noops.
Diffstat (limited to 'arith.c')
-rw-r--r-- | arith.c | 11 |
1 files changed, 11 insertions, 0 deletions
@@ -3288,6 +3288,17 @@ void arith_init(void) reg_fun(intern(lit("poly"), user_package), func_n2(poly)); reg_fun(intern(lit("rpoly"), user_package), func_n2(rpoly)); + reg_fun(intern(lit("b<"), system_package), func_n2(lt)); + reg_fun(intern(lit("b>"), system_package), func_n2(gt)); + reg_fun(intern(lit("b<="), system_package), func_n2(le)); + reg_fun(intern(lit("b=>"), system_package), func_n2(ge)); + reg_fun(intern(lit("b="), system_package), func_n2(numeq)); + reg_fun(intern(lit("b+"), system_package), func_n2(plus)); + reg_fun(intern(lit("b-"), system_package), func_n2(minus)); + reg_fun(intern(lit("b*"), system_package), func_n2(mul)); + reg_fun(intern(lit("b/"), system_package), func_n2(divi)); + reg_fun(intern(lit("neg"), system_package), func_n1(neg)); + #if HAVE_ROUNDING_CTL_H reg_varl(intern(lit("flo-near"), user_package), num(FE_TONEAREST)); reg_varl(intern(lit("flo-down"), user_package), num(FE_DOWNWARD)); |