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 */
|