TraceScan

TraceScan[f,expr]

applies f to all expressions used in the evaluation of expr.

TraceScan[f,expr,form]

includes only those expressions which match form.

TraceScan[f,expr,s]

includes all evaluations which use transformation rules associated with the symbol s.

TraceScan[f,expr,form,fp]

applies f before evaluation and fp after evaluation to expressions used in the evaluation of expr.

Details and Options

  • All expressions are wrapped in HoldForm to prevent evaluation before f or fp are applied to them.
  • The function fp is given as an argument for both the form before evaluation and the form after evaluation.
  • TraceScan[f,expr] returns the result of evaluating expr.

Examples

Basic Examples  (3)

Print all expressions used for evaluation:

In[1]:=
Click for copyable input
Out[1]=

Count additions and multiplications of machine numbers needed for a numerical computation:

In[1]:=
Click for copyable input
Out[1]=

A recursive definition for finding Fibonacci numbers:

In[1]:=
Click for copyable input

Count calls to fib required:

In[2]:=
Click for copyable input
Out[2]=

Redefine fib so that it saves results:

In[3]:=
Click for copyable input

Count calls to fib required:

In[4]:=
Click for copyable input
Out[4]=

The second time through it takes only one call since the value was saved:

In[5]:=
Click for copyable input
Out[5]=

See Also

Trace  TracePrint  TraceDialog

Tutorials

Introduced in 1991
(2.0)