10
1
mirror of https://gitlab.com/scemama/QCaml.git synced 2025-01-03 18:15:47 +01:00
QCaml/common/lib/util.c

98 lines
2.3 KiB
C
Raw Normal View History

2020-12-28 01:08:55 +01:00
/* External C functions */
/* | ~erf_float~ | Error function ~erf~ from =libm= | */
/* | ~erfc_float~ | Complementary error function ~erfc~ from =libm= | */
/* | ~gamma_float~ | Gamma function ~gamma~ from =libm= | */
/* | ~popcnt~ | ~popcnt~ instruction | */
/* | ~trailz~ | ~ctz~ instruction | */
/* | ~leadz~ | ~bsf~ instruction | */
2022-11-07 14:59:11 +01:00
/* [[file:~/QCaml/common/util.org::*External C functions][External C functions:1]] */
2020-12-28 01:08:55 +01:00
#include <math.h>
#include <caml/mlvalues.h>
#include <caml/alloc.h>
/* External C functions:1 ends here */
/* Erf */
2020-12-28 01:55:03 +01:00
/* [[file:~/QCaml/common/util.org::*Erf][Erf:1]] */
2020-12-28 01:08:55 +01:00
CAMLprim value erf_float_bytecode(value x) {
2022-12-12 18:16:17 +01:00
return caml_copy_double(erf(Double_val(x)));
2020-12-28 01:08:55 +01:00
}
CAMLprim double erf_float(double x) {
return erf(x);
}
/* Erf:1 ends here */
/* Erfc */
2020-12-28 01:55:03 +01:00
/* [[file:~/QCaml/common/util.org::*Erfc][Erfc:1]] */
2020-12-28 01:08:55 +01:00
CAMLprim value erfc_float_bytecode(value x) {
2022-12-12 18:16:17 +01:00
return caml_copy_double(erfc(Double_val(x)));
2020-12-28 01:08:55 +01:00
}
CAMLprim double erfc_float(double x) {
return erfc(x);
}
/* Erfc:1 ends here */
/* Gamma */
2020-12-28 01:55:03 +01:00
/* [[file:~/QCaml/common/util.org::*Gamma][Gamma:1]] */
2020-12-28 01:08:55 +01:00
CAMLprim value gamma_float_bytecode(value x) {
2022-12-12 18:16:17 +01:00
return caml_copy_double(tgamma(Double_val(x)));
2020-12-28 01:08:55 +01:00
}
CAMLprim double gamma_float(double x) {
return tgamma(x);
}
/* Gamma:1 ends here */
/* Popcnt */
2020-12-28 01:55:03 +01:00
/* [[file:~/QCaml/common/util.org::*Popcnt][Popcnt:1]] */
2020-12-28 01:08:55 +01:00
CAMLprim int32_t popcnt(int64_t i) {
return __builtin_popcountll (i);
}
CAMLprim value popcnt_bytecode(value i) {
return caml_copy_int32(__builtin_popcountll (Int64_val(i)));
}
/* Popcnt:1 ends here */
/* Trailz */
2020-12-28 01:55:03 +01:00
/* [[file:~/QCaml/common/util.org::*Trailz][Trailz:1]] */
2020-12-28 01:08:55 +01:00
CAMLprim int32_t trailz(int64_t i) {
2023-04-20 10:55:32 +02:00
return i == 0L ? 64 : __builtin_ctzll (i);
2020-12-28 01:08:55 +01:00
}
CAMLprim value trailz_bytecode(value i) {
2023-04-20 10:55:32 +02:00
return caml_copy_int32(i == 0L ? 64 : __builtin_ctzll (Int64_val(i)));
2020-12-28 01:08:55 +01:00
}
/* Trailz:1 ends here */
/* Leadz */
2020-12-28 01:55:03 +01:00
/* [[file:~/QCaml/common/util.org::*Leadz][Leadz:1]] */
2020-12-28 01:08:55 +01:00
CAMLprim int32_t leadz(int64_t i) {
2023-04-20 10:55:32 +02:00
return i == 0L ? 64 : __builtin_clzll(i);
2020-12-28 01:08:55 +01:00
}
CAMLprim value leadz_bytecode(value i) {
2023-04-20 10:55:32 +02:00
return caml_copy_int32(i == 0L ? 64 : __builtin_clzll (Int64_val(i)));
2020-12-28 01:08:55 +01:00
}
/* Leadz:1 ends here */