Bounded Product is Primitive Recursive

Theorem
Let the function $f: \N^{k + 1} \to \N$ be primitive recursive.

Then so is the function $g: \N^{k + 1} \to \N$ defined as:
 * $\map g {n_1, n_2, \ldots, n_k, z} = \begin{cases}

1 & : z = 0 \\ \ds \prod_{y \mathop = 1}^z \map f {n_1, n_2, \ldots, n_k, y} & : z > 0 \end{cases}$

Proof
The function $g$ satisfies:
 * $\map g {n_1, n_2, \ldots, n_k, z} = 0$
 * $\map g {n_1, n_2, \ldots, n_k, z + 1} = \map g {n_1, n_2, \ldots, n_k, z} \times \map f {n_1, n_2, \ldots, n_k, z + 1}$

Hence $g$ is defined by primitive recursion from:
 * the primitive recursive function $\operatorname {Add}$
 * $f$, which is primitive recursive
 * constants, which are primitive recursive.

Hence the result.

Note
The product $\ds \prod_{y \mathop = 1}^z$ is referred to as a bounded product to distinguish it from $\ds \prod_{y \mathop = 1}^\infty$ which is not.