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.