| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *	 YAP Prolog 							 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *	Yap Prolog was developed at NCCUP - Universidade do Porto	 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | * Copyright L.Damas, V.S.Costa and Universidade do Porto 1985-1997	 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | ************************************************************************** | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | * File:		eval.c							 * | 
					
						
							|  |  |  | * Last rev:								 * | 
					
						
							|  |  |  | * mods:									 * | 
					
						
							|  |  |  | * comments:	arithmetical expression evaluation			 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *************************************************************************/ | 
					
						
							|  |  |  | #ifdef SCCS
 | 
					
						
							|  |  |  | static char     SccsId[] = "%W% %G%"; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * This file implements arithmetic operations  | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "Yap.h"
 | 
					
						
							|  |  |  | #include "Yatom.h"
 | 
					
						
							|  |  |  | #include "Heap.h"
 | 
					
						
							|  |  |  | #include "eval.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define E_FUNC   blob_type
 | 
					
						
							|  |  |  | #define E_ARGS   arith_retptr o
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define RINT(v)     (o)->Int = v; return(long_int_e)
 | 
					
						
							|  |  |  | #define RFLOAT(v)   (o)->dbl = v; return(double_e)
 | 
					
						
							|  |  |  | #define RERROR()    return(db_ref_e)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef PI
 | 
					
						
							|  |  |  | #ifdef M_PI
 | 
					
						
							|  |  |  | #define PI M_PI
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define PI 3.14159265358979323846
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static E_FUNC | 
					
						
							|  |  |  | p_pi(E_ARGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   RFLOAT(PI); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef M_E
 | 
					
						
							|  |  |  | #define M_E 2.7182818284590452354
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static E_FUNC | 
					
						
							|  |  |  | p_e(E_ARGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   RFLOAT(M_E); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef INFINITY
 | 
					
						
							|  |  |  | #define INFINITY (1.0/0.0)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static E_FUNC | 
					
						
							|  |  |  | p_inf(E_ARGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #ifdef _MSC_VER /* Microsoft's Visual C++ Compiler */
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_Error(TYPE_ERROR_EVALUABLE, TermNil, "evaluating infinity"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     P = (yamop *)FAILCODE; | 
					
						
							|  |  |  |     RERROR(); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   if (yap_flags[LANGUAGE_MODE_FLAG] == 1) {/* iso */ | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_Error(TYPE_ERROR_EVALUABLE, TermNil, "evaluating infinity"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     P = (yamop *)FAILCODE; | 
					
						
							|  |  |  |     RERROR(); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     RFLOAT(INFINITY); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef NAN
 | 
					
						
							|  |  |  | #define NAN      (0.0/0.0)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-06-22 17:53:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | static E_FUNC | 
					
						
							|  |  |  | p_nan(E_ARGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #ifdef _MSC_VER /* Microsoft's Visual C++ Compiler */
 | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_Error(TYPE_ERROR_EVALUABLE, TermNil, "evaluating infinity"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     P = (yamop *)FAILCODE; | 
					
						
							|  |  |  |     RERROR(); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   if (yap_flags[LANGUAGE_MODE_FLAG] == 1) {/* iso */ | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     Yap_Error(TYPE_ERROR_EVALUABLE, TermNil, "evaluating not-a-number"); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     P = (yamop *)FAILCODE; | 
					
						
							|  |  |  |     RERROR(); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     RFLOAT(NAN); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static E_FUNC | 
					
						
							|  |  |  | p_random(E_ARGS) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   RFLOAT(Yap_random()); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static E_FUNC | 
					
						
							|  |  |  | p_cputime(E_ARGS) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |   RFLOAT((Float)Yap_cputime()/1000.0); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static E_FUNC | 
					
						
							|  |  |  | p_heapused(E_ARGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   RINT(HeapUsed); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static E_FUNC | 
					
						
							|  |  |  | p_localsp(E_ARGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if SBA
 | 
					
						
							|  |  |  |   RINT((Int)ASP); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   RINT(LCL0 - ASP); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static E_FUNC | 
					
						
							|  |  |  | p_b(E_ARGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if SBA
 | 
					
						
							|  |  |  |   RINT((Int)B); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   RINT(LCL0 - (CELL *)B); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-12-17 18:31:11 +00:00
										 |  |  | static E_FUNC | 
					
						
							|  |  |  | p_env(E_ARGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if SBA
 | 
					
						
							|  |  |  |   RINT((Int)YENV); | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2002-01-07 06:28:04 +00:00
										 |  |  |   RINT(LCL0 - YENV); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static E_FUNC | 
					
						
							|  |  |  | p_tr(E_ARGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if SBA
 | 
					
						
							|  |  |  |   RINT(TR); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   RINT(((CELL *)TR)-LCL0); | 
					
						
							| 
									
										
										
										
											2001-12-17 18:31:11 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | static E_FUNC | 
					
						
							|  |  |  | p_globalsp(E_ARGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if SBA
 | 
					
						
							|  |  |  |   RINT((Int)H); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   RINT(H - H0); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static E_FUNC | 
					
						
							|  |  |  | p_stackfree(E_ARGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   RINT(Unsigned(ASP) - Unsigned(H)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef blob_type (*f_constexp)(arith_retptr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct init_const_eval { | 
					
						
							|  |  |  |   char          *OpName; | 
					
						
							|  |  |  |   f_constexp        f; | 
					
						
							|  |  |  | } InitConstEntry; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static InitConstEntry InitConstTab[] = { | 
					
						
							|  |  |  |   {"pi", p_pi}, | 
					
						
							|  |  |  |   {"e", p_e}, | 
					
						
							|  |  |  |   {"inf", p_inf}, | 
					
						
							|  |  |  |   {"nan", p_nan}, | 
					
						
							|  |  |  |   {"random", p_random}, | 
					
						
							|  |  |  |   {"cputime", p_cputime}, | 
					
						
							|  |  |  |   {"heapused", p_heapused}, | 
					
						
							|  |  |  |   {"local_sp", p_localsp}, | 
					
						
							|  |  |  |   {"global_sp", p_globalsp}, | 
					
						
							|  |  |  |   {"$last_choice_pt", p_b}, | 
					
						
							| 
									
										
										
										
											2001-12-17 18:31:11 +00:00
										 |  |  |   {"$env", p_env}, | 
					
						
							| 
									
										
										
										
											2002-01-07 06:28:04 +00:00
										 |  |  |   {"$tr", p_tr}, | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   {"stackfree", p_stackfree}, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_InitConstExps(void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   unsigned int    i; | 
					
						
							|  |  |  |   ExpEntry       *p; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for (i = 0; i < sizeof(InitConstTab)/sizeof(InitConstEntry); ++i) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     AtomEntry *ae = RepAtom(Yap_LookupAtom(InitConstTab[i].OpName)); | 
					
						
							| 
									
										
										
										
											2005-03-01 22:25:09 +00:00
										 |  |  |     if (ae == NULL) { | 
					
						
							|  |  |  |       Yap_Error(OUT_OF_HEAP_ERROR,TermNil,"at InitConstExps"); | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     WRITE_LOCK(ae->ARWLock); | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     if (Yap_GetExpPropHavingLock(ae, 0)) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       WRITE_UNLOCK(ae->ARWLock); | 
					
						
							|  |  |  |       break; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     p = (ExpEntry *) Yap_AllocAtomSpace(sizeof(ExpEntry)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     p->KindOfPE = ExpProperty; | 
					
						
							|  |  |  |     p->ArityOfEE = 0; | 
					
						
							|  |  |  |     p->ENoOfEE = 0; | 
					
						
							|  |  |  |     p->FOfEE.constant = InitConstTab[i].f; | 
					
						
							| 
									
										
										
										
											2001-10-30 16:42:05 +00:00
										 |  |  |     p->NextOfPE = ae->PropsOfAE; | 
					
						
							|  |  |  |     ae->PropsOfAE = AbsExpProp(p); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     WRITE_UNLOCK(ae->ARWLock); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* This routine is called from Restore to make sure we have the same arithmetic operators */ | 
					
						
							|  |  |  | int | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  | Yap_ReInitConstExps(void) | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   unsigned int i; | 
					
						
							|  |  |  |   Prop p; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for (i = 0; i < sizeof(InitConstTab)/sizeof(InitConstEntry); ++i) { | 
					
						
							| 
									
										
										
										
											2002-11-18 18:18:05 +00:00
										 |  |  |     AtomEntry *ae = RepAtom(Yap_FullLookupAtom(InitConstTab[i].OpName)); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     WRITE_LOCK(ae->ARWLock); | 
					
						
							| 
									
										
										
										
											2005-10-31 12:27:54 +00:00
										 |  |  |     if (!(p = Yap_GetExpPropHavingLock(ae, 0))) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       WRITE_UNLOCK(ae->ARWLock); | 
					
						
							| 
									
										
										
										
											2005-10-31 12:27:54 +00:00
										 |  |  |       return FALSE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     RepExpProp(p)->FOfEE.constant = InitConstTab[i].f; | 
					
						
							|  |  |  |     WRITE_UNLOCK(ae->ARWLock); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2005-10-31 12:27:54 +00:00
										 |  |  |   return TRUE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 |