/************************************************************************* * * * YAP Prolog @(#)eval.h 1.2 * * * Yap Prolog was developed at NCCUP - Universidade do Porto * * * * Copyright L.Damas, V.S.Costa and Universidade do Porto 1985-1997 * * * ************************************************************************** * * * File: eval.h * * Last rev: * * mods: * * comments: arithmetical functions info * * * *************************************************************************/ #include <stdlib.h> /* C library used to implement floating point functions */ #if HAVE_MATH_H #include <math.h> #endif #ifdef HAVE_FLOAT_H #include <float.h> #endif #ifdef HAVE_IEEEFP_H #include <ieeefp.h> #endif #ifdef HAVE_LIMITS_H #include <limits.h> #endif #ifdef LONG_MAX #define Int_MAX LONG_MAX #else #define Int_MAX ((Int)((~((CELL)0))>>1)) #endif #ifdef LONG_MIN #define Int_MIN LONG_MIN #else #define Int_MIN (-Int_MAX-(CELL)1) #endif typedef enum { op_pi, op_e, op_epsilon, op_inf, op_nan, op_random, op_cputime, op_heapused, op_localsp, op_globalsp, op_b, op_env, op_tr, op_stackfree } arith0_op; typedef enum { op_uplus, op_uminus, op_unot, op_exp, op_log, op_log10, op_sqrt, op_sin, op_cos, op_tan, op_sinh, op_cosh, op_tanh, op_asin, op_acos, op_atan, op_asinh, op_acosh, op_atanh, op_floor, op_ceiling, op_round, op_truncate, op_integer, op_float, op_abs, op_lsb, op_msb, op_popcount, op_ffracp, op_fintp, op_sign, op_lgamma, op_random1 } arith1_op; typedef enum { op_plus, op_minus, op_times, op_fdiv, op_mod, op_rem, op_div, op_sll, op_slr, op_and, op_or, op_xor, op_atan2, /* C-Prolog exponentiation */ op_power, /* ISO-Prolog exponentiation */ /* op_power, */ op_power2, /* Quintus exponentiation */ /* op_power, */ op_gcd, op_min, op_max } arith2_op; Functor STD_PROTO(EvalArg,(Term)); /* Needed to handle numbers: these two macros are fundamental in the integer/float conversions */ #ifdef C_PROLOG #define FlIsInt(X) ( (X) == (Int)(X) && IntInBnd((X)) ) #else #define FlIsInt(X) ( FALSE ) #endif #ifdef M_WILLIAMS #define MkEvalFl(X) MkFloatTerm(X) #else #define MkEvalFl(X) ( FlIsInt(X) ? MkIntTerm((Int)(X)) : MkFloatTerm(X) ) #endif /* Macros used by some of the eval functions */ #define REvalInt(I) { eval_int = (I); return(FInt); } #define REvalFl(F) { eval_flt = (F); return(FFloat); } #define REvalError() { return(FError); } /* this macro, dependent on the particular implementation is used to interface the arguments into the C libraries */ #ifdef MPW #define FL(X) ((extended)(X)) #else #define FL(X) ((double)(X)) #endif extern yap_error_number Yap_matherror; void STD_PROTO(Yap_InitConstExps,(void)); void STD_PROTO(Yap_InitUnaryExps,(void)); void STD_PROTO(Yap_InitBinaryExps,(void)); int STD_PROTO(Yap_ReInitConstExps,(void)); int STD_PROTO(Yap_ReInitUnaryExps,(void)); int STD_PROTO(Yap_ReInitBinaryExps,(void)); Term STD_PROTO(Yap_eval_atom,(Int)); Term STD_PROTO(Yap_eval_unary,(Int,Term)); Term STD_PROTO(Yap_eval_binary,(Int,Term,Term)); Term STD_PROTO(Yap_Eval,(Term)); Int STD_PROTO(Yap_ArithError,(yap_error_number,Term,char *msg, ...)); inline static Term Yap_FoundArithError(Term t, Term inp) { if (Yap_Error_TYPE) { Yap_Error(Yap_Error_TYPE, (inp ? inp : Yap_Error_Term), Yap_ErrorMessage); P = FAILCODE; return 0L; } return t; } #define RINT(v) return(MkIntegerTerm(v)) #define RFLOAT(v) return(MkFloatTerm(v)) #define RBIG(v) return(Yap_MkBigIntTerm(v)) #define RERROR() return(0L) static inline blob_type ETypeOfTerm(Term t) { if (IsIntTerm(t)) return long_int_e; if (IsApplTerm(t)) { Functor f = FunctorOfTerm(t); if (f == FunctorDouble) return double_e; if (f == FunctorLongInt) return long_int_e; if (f == FunctorBigInt) return big_int_e; } return db_ref_e; } #if USE_GMP Term STD_PROTO(Yap_gmp_add_ints,(Int, Int)); Term STD_PROTO(Yap_gmp_sub_ints,(Int, Int)); Term STD_PROTO(Yap_gmp_mul_ints,(Int, Int)); Term STD_PROTO(Yap_gmp_sll_ints,(Int, Int)); Term STD_PROTO(Yap_gmp_add_int_big,(Int, MP_INT *)); Term STD_PROTO(Yap_gmp_sub_int_big,(Int, MP_INT *)); Term STD_PROTO(Yap_gmp_sub_big_int,(MP_INT *, Int)); Term STD_PROTO(Yap_gmp_mul_int_big,(Int, MP_INT *)); Term STD_PROTO(Yap_gmp_div_big_int,(MP_INT *, Int)); Term STD_PROTO(Yap_gmp_and_int_big,(Int, MP_INT *)); Term STD_PROTO(Yap_gmp_ior_int_big,(Int, MP_INT *)); Term STD_PROTO(Yap_gmp_sll_big_int,(MP_INT *, Int)); Term STD_PROTO(Yap_gmp_add_big_big,(MP_INT *, MP_INT *)); Term STD_PROTO(Yap_gmp_sub_big_big,(MP_INT *, MP_INT *)); Term STD_PROTO(Yap_gmp_mul_big_big,(MP_INT *, MP_INT *)); Term STD_PROTO(Yap_gmp_div_big_big,(MP_INT *, MP_INT *)); Term STD_PROTO(Yap_gmp_and_big_big,(MP_INT *, MP_INT *)); Term STD_PROTO(Yap_gmp_ior_big_big,(MP_INT *, MP_INT *)); Term STD_PROTO(Yap_gmp_mod_big_big,(MP_INT *, MP_INT *)); Term STD_PROTO(Yap_gmp_mod_big_int,(MP_INT *, Int)); Term STD_PROTO(Yap_gmp_mod_int_big,(Int, MP_INT *)); Term STD_PROTO(Yap_gmp_exp_ints,(Int,Int)); Term STD_PROTO(Yap_gmp_exp_big_int,(MP_INT *,Int)); Term STD_PROTO(Yap_gmp_big_from_64bits,(YAP_LONG_LONG)); Term STD_PROTO(Yap_gmp_add_float_big,(Float, MP_INT *)); Term STD_PROTO(Yap_gmp_sub_float_big,(Float, MP_INT *)); Term STD_PROTO(Yap_gmp_sub_big_float,(MP_INT *, Float)); Term STD_PROTO(Yap_gmp_mul_float_big,(Float, MP_INT *)); #endif inline EXTERN Term Yap_Mk64IntegerTerm(YAP_LONG_LONG); inline EXTERN Term Yap_Mk64IntegerTerm(YAP_LONG_LONG i) { if (i <= Int_MAX && i >= Int_MIN) { return MkIntegerTerm((Int)i); } else { #if USE_GMP return Yap_gmp_big_from_64bits(i); #else return MkIntTerm(-1); #endif } }