2001-04-09 20:54:03 +01: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: it_deep.c *
|
|
|
|
* Last rev: *
|
|
|
|
* mods: *
|
|
|
|
* comments: Support for Iterative Deepening *
|
|
|
|
* *
|
|
|
|
*************************************************************************/
|
|
|
|
#ifdef SCCS
|
|
|
|
static char SccsId[] = "%W% %G%";
|
|
|
|
#endif /* SCCS */
|
|
|
|
|
2013-01-20 23:15:09 +00:00
|
|
|
#include <math.h>
|
|
|
|
#ifndef INFINITY
|
|
|
|
#define INFINITY (1.0/0.0)
|
|
|
|
#endif
|
|
|
|
|
2001-04-09 20:54:03 +01:00
|
|
|
#include "Yap.h"
|
|
|
|
|
|
|
|
#ifdef DEPTH_LIMIT
|
|
|
|
|
|
|
|
#include "Yatom.h"
|
|
|
|
|
2013-04-25 23:15:04 +01:00
|
|
|
static Int p_get_depth_limit( USES_REGS1 );
|
|
|
|
static Int p_set_depth_limit( USES_REGS1 );
|
2001-04-09 20:54:03 +01:00
|
|
|
|
2011-03-07 16:02:55 +00:00
|
|
|
static Int p_get_depth_limit( USES_REGS1 )
|
2001-04-09 20:54:03 +01:00
|
|
|
{
|
2013-01-20 23:15:09 +00:00
|
|
|
Int d = IntOfTerm(DEPTH);
|
|
|
|
if (d % 2 == 1)
|
|
|
|
return(Yap_unify(ARG1, MkFloatTerm(INFINITY)));
|
|
|
|
return(Yap_unify_constant(ARG1, MkIntTerm(d/2)));
|
2001-04-09 20:54:03 +01:00
|
|
|
}
|
|
|
|
|
2011-03-07 16:02:55 +00:00
|
|
|
static Int p_set_depth_limit( USES_REGS1 )
|
2001-04-09 20:54:03 +01:00
|
|
|
{
|
|
|
|
Term d = Deref(ARG1);
|
|
|
|
|
|
|
|
if (IsVarTerm(d)) {
|
2002-11-18 18:18:05 +00:00
|
|
|
Yap_Error(INSTANTIATION_ERROR, d, "set-depth_limit");
|
2001-04-09 20:54:03 +01:00
|
|
|
return(FALSE);
|
|
|
|
} else if (!IsIntegerTerm(d)) {
|
2013-01-20 23:15:09 +00:00
|
|
|
if (IsFloatTerm(d) && isinf(FloatOfTerm(d))) {
|
|
|
|
d = RESET_DEPTH();
|
|
|
|
} else {
|
|
|
|
Yap_Error(TYPE_ERROR_INTEGER, d, "set-depth_limit");
|
|
|
|
return(FALSE);
|
|
|
|
}
|
2001-04-09 20:54:03 +01:00
|
|
|
}
|
|
|
|
d = MkIntTerm(IntegerOfTerm(d)*2);
|
|
|
|
|
|
|
|
YENV[E_DEPTH] = d;
|
|
|
|
DEPTH = d;
|
|
|
|
|
|
|
|
return(TRUE);
|
|
|
|
}
|
|
|
|
|
2011-03-07 16:02:55 +00:00
|
|
|
static Int p_set_depth_limit_for_next_call( USES_REGS1 )
|
2003-01-30 16:27:45 +00:00
|
|
|
{
|
|
|
|
Term d = Deref(ARG1);
|
|
|
|
|
|
|
|
if (IsVarTerm(d)) {
|
|
|
|
Yap_Error(INSTANTIATION_ERROR, d, "set-depth_limit");
|
|
|
|
return(FALSE);
|
|
|
|
} else if (!IsIntegerTerm(d)) {
|
2013-01-20 23:15:09 +00:00
|
|
|
if (IsFloatTerm(d) && isinf(FloatOfTerm(d))) {
|
|
|
|
DEPTH = RESET_DEPTH();
|
|
|
|
return TRUE;
|
|
|
|
}
|
2003-01-30 16:27:45 +00:00
|
|
|
Yap_Error(TYPE_ERROR_INTEGER, d, "set-depth_limit");
|
|
|
|
return(FALSE);
|
|
|
|
}
|
|
|
|
d = MkIntTerm(IntegerOfTerm(d)*2);
|
|
|
|
|
|
|
|
DEPTH = d;
|
|
|
|
|
|
|
|
return(TRUE);
|
|
|
|
}
|
|
|
|
|
2002-11-18 18:18:05 +00:00
|
|
|
void Yap_InitItDeepenPreds(void)
|
2001-04-09 20:54:03 +01:00
|
|
|
{
|
2002-11-18 18:18:05 +00:00
|
|
|
Yap_InitCPred("get_depth_limit", 1, p_get_depth_limit, SafePredFlag);
|
2012-10-19 18:10:48 +01:00
|
|
|
Yap_InitCPred("$set_depth_limit", 1, p_set_depth_limit, 0);
|
|
|
|
Yap_InitCPred("$set_depth_limit_for_next_call", 1, p_set_depth_limit_for_next_call, 0);
|
2001-04-09 20:54:03 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|