1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
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
}
|