A transformation applied to functional programs to replace recursion with iteration. A tail-recursive function can Be compiled to an iterative loop where the recursive call Becomes a jump Back to the start and the parameters are held in registers which are updated with new values each time around the loop. See Iteration, Tail recursion optimisation.