diff options
| author | Kimplul <kimi.h.kuparinen@gmail.com> | 2025-04-01 22:16:25 +0300 | 
|---|---|---|
| committer | Kimplul <kimi.h.kuparinen@gmail.com> | 2025-04-01 22:16:25 +0300 | 
| commit | 478c92b425eca53a0d884fb8f5dea8d769016858 (patch) | |
| tree | d5d85feb1b796530429221d51ab88c8c7f1a0b55 /tests | |
| parent | 4135845b93d5c0eab23ad5da526b03a911878d67 (diff) | |
| download | ejit-478c92b425eca53a0d884fb8f5dea8d769016858.tar.gz ejit-478c92b425eca53a0d884fb8f5dea8d769016858.zip | |
expose sqrt
+ Requires linking with libm in some cases, which is fine I suppose, but
  kind of annoying
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/sqrtr_d.c | 23 | ||||
| -rw-r--r-- | tests/sqrtr_f.c | 23 | 
2 files changed, 46 insertions, 0 deletions
| diff --git a/tests/sqrtr_d.c b/tests/sqrtr_d.c new file mode 100644 index 0000000..06e7894 --- /dev/null +++ b/tests/sqrtr_d.c @@ -0,0 +1,23 @@ +#include <ejit/ejit.h> +#include <assert.h> +#include "do_jit.h" + +int main(int argc, char *argv[]) +{ +        (void)argv; +        bool do_jit = argc > 1; +        struct ejit_operand operands[1] = { +                EJIT_OPERAND_FPR(0, EJIT_TYPE(double)), +        }; +        struct ejit_func *f = ejit_create_func(EJIT_TYPE(double), 1, operands); + +        ejit_sqrtr_d(f, EJIT_FPR(0), EJIT_FPR(0)); +        ejit_retr_d(f, EJIT_FPR(0)); + +        ejit_select_compile_func(f, 0, 1, EJIT_USE64(double), do_jit, true); + +        assert(erfd1(f, EJIT_ARG( 0.0, double)) == 0.0); +        assert(erfd1(f, EJIT_ARG( 4.0, double)) == 2.0); +        assert(erfd1(f, EJIT_ARG(-4.0, double)) +                        != erfd1(f, EJIT_ARG(-4.0, double))); // nan +} diff --git a/tests/sqrtr_f.c b/tests/sqrtr_f.c new file mode 100644 index 0000000..3baa00d --- /dev/null +++ b/tests/sqrtr_f.c @@ -0,0 +1,23 @@ +#include <ejit/ejit.h> +#include <assert.h> +#include "do_jit.h" + +int main(int argc, char *argv[]) +{ +        (void)argv; +        bool do_jit = argc > 1; +        struct ejit_operand operands[1] = { +                EJIT_OPERAND_FPR(0, EJIT_TYPE(float)), +        }; +        struct ejit_func *f = ejit_create_func(EJIT_TYPE(float), 1, operands); + +        ejit_sqrtr_f(f, EJIT_FPR(0), EJIT_FPR(0)); +        ejit_retr_f(f, EJIT_FPR(0)); + +        ejit_select_compile_func(f, 0, 1, EJIT_USE64(float), do_jit, true); + +        assert(erff1(f, EJIT_ARG( 0.0, float)) == 0.0); +        assert(erff1(f, EJIT_ARG( 4.0, float)) == 2.0); +        assert(erff1(f, EJIT_ARG(-4.0, float)) +                        != erff1(f, EJIT_ARG(-4.0, float))); // nan +} | 
