Further updates to support call_counters

git-svn-id: https://yap.svn.sf.net/svnroot/yap/trunk@581 b08c6af1-5177-4d33-ba66-4b1c6b8b522a
This commit is contained in:
vsc 2002-09-03 20:14:13 +00:00
parent 94e9529128
commit 708437b794
2 changed files with 64 additions and 4 deletions

View File

@ -298,7 +298,9 @@ absmi(int inp)
restore_absmi_regs(old_regs); restore_absmi_regs(old_regs);
#endif #endif
if (!growheap(FALSE)) { if (!growheap(FALSE)) {
saveregs();
Error(SYSTEM_ERROR, TermNil, "YAP failed to reserve space in growheap"); Error(SYSTEM_ERROR, TermNil, "YAP failed to reserve space in growheap");
setregs();
FAIL(); FAIL();
} }
goto reset_absmi; goto reset_absmi;
@ -324,7 +326,9 @@ absmi(int inp)
restore_absmi_regs(old_regs); restore_absmi_regs(old_regs);
#endif #endif
if(!growtrail (sizeof(CELL) * 16 * 1024L)) { if(!growtrail (sizeof(CELL) * 16 * 1024L)) {
saveregs();
Error(SYSTEM_ERROR,TermNil,"YAP failed to reserve %ld bytes in growtrail",sizeof(CELL) * 16 * 1024L); Error(SYSTEM_ERROR,TermNil,"YAP failed to reserve %ld bytes in growtrail",sizeof(CELL) * 16 * 1024L);
setregs();
FAIL(); FAIL();
} }
goto reset_absmi; goto reset_absmi;
@ -529,14 +533,21 @@ absmi(int inp)
/* count_enter_me Label,NArgs */ /* count_enter_me Label,NArgs */
Op(count_call, l); Op(count_call, l);
LOCK(((PredEntry *)(PREG->u.l.l))->StatisticsForPred.lock);
((PredEntry *)(PREG->u.l.l))->StatisticsForPred.NOfEntries++;
UNLOCK(((PredEntry *)(PREG->u.l.l))->StatisticsForPred.lock);
ReductionsCounter--; ReductionsCounter--;
if (ReductionsCounter == 0 && ReductionsCounterOn) { if (ReductionsCounter == 0 && ReductionsCounterOn) {
saveregs();
Error(CALL_COUNTER_UNDERFLOW,TermNil,""); Error(CALL_COUNTER_UNDERFLOW,TermNil,"");
setregs();
JMPNext(); JMPNext();
} }
PredEntriesCounter--; PredEntriesCounter--;
if (PredEntriesCounter == 0 && PredEntriesCounterOn) { if (PredEntriesCounter == 0 && PredEntriesCounterOn) {
saveregs();
Error(PRED_ENTRY_COUNTER_UNDERFLOW,TermNil,""); Error(PRED_ENTRY_COUNTER_UNDERFLOW,TermNil,"");
setregs();
JMPNext(); JMPNext();
} }
PREG = NEXTOP(PREG, l); PREG = NEXTOP(PREG, l);
@ -545,14 +556,21 @@ absmi(int inp)
/* count_retry Label,NArgs */ /* count_retry Label,NArgs */
Op(count_retry, l); Op(count_retry, l);
LOCK(((PredEntry *)(PREG->u.l.l))->StatisticsForPred.lock);
((PredEntry *)(PREG->u.l.l))->StatisticsForPred.NOfRetries++;
UNLOCK(((PredEntry *)(PREG->u.l.l))->StatisticsForPred.lock);
RetriesCounter--; RetriesCounter--;
if (RetriesCounter == 0 && RetriesCounterOn) { if (RetriesCounter == 0 && RetriesCounterOn) {
saveregs();
Error(RETRY_COUNTER_UNDERFLOW,TermNil,""); Error(RETRY_COUNTER_UNDERFLOW,TermNil,"");
JMPNext(); JMPNext();
setregs();
} }
PredEntriesCounter--; PredEntriesCounter--;
if (PredEntriesCounter == 0 && PredEntriesCounterOn) { if (PredEntriesCounter == 0 && PredEntriesCounterOn) {
saveregs();
Error(PRED_ENTRY_COUNTER_UNDERFLOW,TermNil,""); Error(PRED_ENTRY_COUNTER_UNDERFLOW,TermNil,"");
setregs();
JMPNext(); JMPNext();
} }
PREG = NEXTOP(PREG, l); PREG = NEXTOP(PREG, l);
@ -564,14 +582,21 @@ absmi(int inp)
CACHE_Y(B); CACHE_Y(B);
/* After retry, cut should be pointing at the parent /* After retry, cut should be pointing at the parent
* choicepoint for the current B */ * choicepoint for the current B */
LOCK(((PredEntry *)(PREG->u.ld.p))->StatisticsForPred.lock);
((PredEntry *)(PREG->u.ld.p))->StatisticsForPred.NOfRetries++;
UNLOCK(((PredEntry *)(PREG->u.ld.p))->StatisticsForPred.lock);
RetriesCounter--; RetriesCounter--;
if (RetriesCounter == 0 && RetriesCounterOn) { if (RetriesCounter == 0 && RetriesCounterOn) {
saveregs();
Error(RETRY_COUNTER_UNDERFLOW,TermNil,""); Error(RETRY_COUNTER_UNDERFLOW,TermNil,"");
setregs();
JMPNext(); JMPNext();
} }
PredEntriesCounter--; PredEntriesCounter--;
if (PredEntriesCounter == 0 && PredEntriesCounterOn) { if (PredEntriesCounter == 0 && PredEntriesCounterOn) {
saveregs();
Error(PRED_ENTRY_COUNTER_UNDERFLOW,TermNil,""); Error(PRED_ENTRY_COUNTER_UNDERFLOW,TermNil,"");
setregs();
JMPNext(); JMPNext();
} }
restore_yaam_regs(PREG->u.ld.d); restore_yaam_regs(PREG->u.ld.d);
@ -616,14 +641,21 @@ absmi(int inp)
ENDCACHE_Y(); ENDCACHE_Y();
RetriesCounter--; RetriesCounter--;
if (RetriesCounter == 0) { if (RetriesCounter == 0) {
saveregs();
Error(RETRY_COUNTER_UNDERFLOW,TermNil,""); Error(RETRY_COUNTER_UNDERFLOW,TermNil,"");
setregs();
JMPNext(); JMPNext();
} }
PredEntriesCounter--; PredEntriesCounter--;
if (PredEntriesCounter == 0) { if (PredEntriesCounter == 0) {
saveregs();
Error(PRED_ENTRY_COUNTER_UNDERFLOW,TermNil,""); Error(PRED_ENTRY_COUNTER_UNDERFLOW,TermNil,"");
setregs();
JMPNext(); JMPNext();
} }
LOCK(((PredEntry *)(PREG->u.ld.p))->StatisticsForPred.lock);
((PredEntry *)(PREG->u.ld.p))->StatisticsForPred.NOfRetries++;
UNLOCK(((PredEntry *)(PREG->u.ld.p))->StatisticsForPred.lock);
PREG = NEXTOP(PREG, ld); PREG = NEXTOP(PREG, ld);
GONext(); GONext();
ENDOp(); ENDOp();
@ -1179,15 +1211,18 @@ absmi(int inp)
BOp(count_retry_and_mark, ld); BOp(count_retry_and_mark, ld);
RetriesCounter--; RetriesCounter--;
if (RetriesCounter == 0) { if (RetriesCounter == 0) {
saveregs();
Error(RETRY_COUNTER_UNDERFLOW,TermNil,""); Error(RETRY_COUNTER_UNDERFLOW,TermNil,"");
setregs();
JMPNext(); JMPNext();
} }
PredEntriesCounter--; PredEntriesCounter--;
if (PredEntriesCounter == 0) { if (PredEntriesCounter == 0) {
saveregs();
Error(PRED_ENTRY_COUNTER_UNDERFLOW,TermNil,""); Error(PRED_ENTRY_COUNTER_UNDERFLOW,TermNil,"");
setregs();
JMPNext(); JMPNext();
} }
goto actual_retry_and_mark;
/* enter a retry dynamic */ /* enter a retry dynamic */
ENDBOp(); ENDBOp();
@ -1200,7 +1235,6 @@ absmi(int inp)
/* retry_and_mark Label,NArgs */ /* retry_and_mark Label,NArgs */
BOp(retry_and_mark, ld); BOp(retry_and_mark, ld);
actual_retry_and_mark:
#ifdef YAPOR #ifdef YAPOR
CUT_wait_leftmost(); CUT_wait_leftmost();
#endif /* YAPOR */ #endif /* YAPOR */

View File

@ -155,7 +155,7 @@ Built In Predicates
* OS:: Access to Operating System Functionality * OS:: Access to Operating System Functionality
* Term Modification:: Updating Prolog Terms * Term Modification:: Updating Prolog Terms
* Profiling:: Profiling Prolog Execution * Profiling:: Profiling Prolog Execution
* Calls Execution Limits:: Limiting the Maximum Number of Reductions * Call Counting:: Limiting the Maximum Number of Reductions
* Arrays:: Supporting Global and Local Arrays * Arrays:: Supporting Global and Local Arrays
* Preds:: Information on Predicates * Preds:: Information on Predicates
* Misc:: Miscellaneous Predicates * Misc:: Miscellaneous Predicates
@ -2035,7 +2035,7 @@ Builtins, Debugging, Syntax, Top
* OS:: Access to Operating System Functionality * OS:: Access to Operating System Functionality
* Term Modification:: Updating Prolog Terms * Term Modification:: Updating Prolog Terms
* Profiling:: Profiling Prolog Execution * Profiling:: Profiling Prolog Execution
* Calls Execution Limits:: Limiting the Maximum Number of Reductions * Call Counting:: Limiting the Maximum Number of Reductions
* Arrays:: Supporting Global and Local Arrays * Arrays:: Supporting Global and Local Arrays
* Preds:: Information on Predicates * Preds:: Information on Predicates
* Misc:: Miscellaneous Predicates * Misc:: Miscellaneous Predicates
@ -5744,6 +5744,10 @@ retries.
These counters can be used to find out how many calls a certain These counters can be used to find out how many calls a certain
goal takes to execute. They can also be used as timers. goal takes to execute. They can also be used as timers.
The code for the call counters piggybacks on the profiling
code. Therefore, activating the call counters also activates the call
counters.
These are the predicates that access and manipulate the call counters: These are the predicates that access and manipulate the call counters:
@table @code @table @code
@ -5778,7 +5782,29 @@ counter @code{retries} reaches 0;
reaches 0. reaches 0.
@end itemize @end itemize
Next, we show a simple example of how to use call counters:
@example
G(X,Y,Z,I,J) :-
array_element(X,I,E1),
array_element(Y,J,E2),
array_element(Z,I,E3),
E1 is E2+E3.
@end example
?- yap_flag(call_counting,on), [-user]. l :- l. end_of_file. yap_flag(call_counting,off).
yes
yes
?- catch((call_count(10000,_,_),l),call_counter,format("limit_exceeded.~n",[])).
limit_exceeded.
yes
@end table @end table
Notice that we first compile the looping predicate @code{l/0} with
@code{call_counting} @code{on}. Next, we @code{catch/3} to handle an
exception when @code{l/0} performs more than 10000 reductions.
@node Arrays, Preds, Profiling , Top @node Arrays, Preds, Profiling , Top
@section Arrays @section Arrays